1 /* $OpenBSD: pucdata.c,v 1.14 2001/08/11 09:47:12 deraadt Exp $ */ 2 /* $NetBSD: pucdata.c,v 1.6 1999/07/03 05:55:23 cgd Exp $ */ 3 4 /* 5 * Copyright (c) 1998, 1999 Christopher G. Demetriou. All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 3. All advertising materials mentioning features or use of this software 16 * must display the following acknowledgement: 17 * This product includes software developed by Christopher G. Demetriou 18 * for the NetBSD Project. 19 * 4. The name of the author may not be used to endorse or promote products 20 * derived from this software without specific prior written permission 21 * 22 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 23 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 24 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 25 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 27 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 31 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 32 */ 33 34 /* 35 * PCI "universal" communications card driver configuration data (used to 36 * match/attach the cards). 37 */ 38 39 #include <sys/param.h> 40 #include <sys/systm.h> 41 #include <sys/device.h> 42 43 #include <dev/pci/pcireg.h> 44 #include <dev/pci/pcivar.h> 45 #include <dev/pci/pucvar.h> 46 #include <dev/pci/pcidevs.h> 47 #include <dev/ic/comreg.h> 48 49 const struct puc_device_description puc_devices[] = { 50 /* 51 * XXX no entry because I have no data: 52 * XXX Dolphin Peripherals 4006 (single parallel) 53 */ 54 55 /* 56 * Dolphin Peripherals 4014 (dual parallel port) card. PLX 9050, with 57 * a seemingly-lame EEPROM setup that puts the Dolphin IDs 58 * into the subsystem fields, and claims that it's a 59 * network/misc (0x02/0x80) device. 60 */ 61 { /* "Dolphin Peripherals 4014", */ 62 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0xd84d, 0x6810 }, 63 { 0xffff, 0xffff, 0xffff, 0xffff }, 64 { 65 { PUC_PORT_TYPE_LPT, 0x20, 0x00 }, 66 { PUC_PORT_TYPE_LPT, 0x24, 0x00 }, 67 }, 68 }, 69 70 /* 71 * XXX no entry because I have no data: 72 * XXX Dolphin Peripherals 4025 (single serial) 73 */ 74 75 /* 76 * Dolphin Peripherals 4035 (dual serial port) card. PLX 9050, with 77 * a seemingly-lame EEPROM setup that puts the Dolphin IDs 78 * into the subsystem fields, and claims that it's a 79 * network/misc (0x02/0x80) device. 80 */ 81 { /* "Dolphin Peripherals 4035", */ 82 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0xd84d, 0x6808 }, 83 { 0xffff, 0xffff, 0xffff, 0xffff }, 84 { 85 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 86 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 87 }, 88 }, 89 90 /* 91 * XXX no entry because I have no data: 92 * XXX Dolphin Peripherals 4078 (dual serial and single parallel) 93 */ 94 95 96 /* 97 * SIIG Boards. 98 * 99 * SIIG provides documentation for their boards at: 100 * <URL:http://www.siig.com/driver.htm> 101 * 102 * Please excuse the weird ordering, it's the order they 103 * use in their documentation. 104 */ 105 106 /* 107 * SIIG "10x" family boards. 108 */ 109 110 /* SIIG Cyber Serial PCI 16C550 (10x family): 1S */ 111 { /* "SIIG Cyber Serial PCI 16C550 (10x family)", */ 112 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1000, 0, 0 }, 113 { 0xffff, 0xffff, 0, 0 }, 114 { 115 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 116 }, 117 }, 118 119 /* SIIG Cyber Serial PCI 16C650 (10x family): 1S */ 120 { /* "SIIG Cyber Serial PCI 16C650 (10x family)", */ 121 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1001, 0, 0 }, 122 { 0xffff, 0xffff, 0, 0 }, 123 { 124 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 125 }, 126 }, 127 128 /* SIIG Cyber Serial PCI 16C850 (10x family): 1S */ 129 { /* "SIIG Cyber Serial PCI 16C850 (10x family)", */ 130 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1002, 0, 0 }, 131 { 0xffff, 0xffff, 0, 0 }, 132 { 133 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 134 }, 135 }, 136 137 /* SIIG Cyber I/O PCI 16C550 (10x family): 1S, 1P */ 138 { /* "SIIG Cyber I/O PCI 16C550 (10x family)", */ 139 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1010, 0, 0 }, 140 { 0xffff, 0xffff, 0, 0 }, 141 { 142 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 143 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 144 }, 145 }, 146 147 /* SIIG Cyber I/O PCI 16C650 (10x family): 1S, 1P */ 148 { /* "SIIG Cyber I/O PCI 16C650 (10x family)", */ 149 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1011, 0, 0 }, 150 { 0xffff, 0xffff, 0, 0 }, 151 { 152 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 153 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 154 }, 155 }, 156 157 /* SIIG Cyber I/O PCI 16C850 (10x family): 1S, 1P */ 158 { /* "SIIG Cyber I/O PCI 16C850 (10x family)", */ 159 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1012, 0, 0 }, 160 { 0xffff, 0xffff, 0, 0 }, 161 { 162 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 163 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 164 }, 165 }, 166 167 /* SIIG Cyber Parallel PCI (10x family): 1P */ 168 { /* "SIIG Cyber Parallel PCI (10x family)", */ 169 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1020, 0, 0 }, 170 { 0xffff, 0xffff, 0, 0 }, 171 { 172 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 173 }, 174 }, 175 176 /* SIIG Cyber Parallel Dual PCI (10x family): 2P */ 177 { /* "SIIG Cyber Parallel Dual PCI (10x family)", */ 178 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1021, 0, 0 }, 179 { 0xffff, 0xffff, 0, 0 }, 180 { 181 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 182 { PUC_PORT_TYPE_LPT, 0x20, 0x00 }, 183 }, 184 }, 185 186 /* SIIG Cyber Serial Dual PCI 16C550 (10x family): 2S */ 187 { /* "SIIG Cyber Serial Dual PCI 16C550 (10x family)", */ 188 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1030, 0, 0 }, 189 { 0xffff, 0xffff, 0, 0 }, 190 { 191 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 192 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 193 }, 194 }, 195 196 /* SIIG Cyber Serial Dual PCI 16C650 (10x family): 2S */ 197 { /* "SIIG Cyber Serial Dual PCI 16C650 (10x family)", */ 198 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1031, 0, 0 }, 199 { 0xffff, 0xffff, 0, 0 }, 200 { 201 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 202 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 203 }, 204 }, 205 206 /* SIIG Cyber Serial Dual PCI 16C850 (10x family): 2S */ 207 { /* "SIIG Cyber Serial Dual PCI 16C850 (10x family)", */ 208 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1032, 0, 0 }, 209 { 0xffff, 0xffff, 0, 0 }, 210 { 211 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 212 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 213 }, 214 }, 215 216 /* SIIG Cyber 2S1P PCI 16C550 (10x family): 2S, 1P */ 217 { /* "SIIG Cyber 2S1P PCI 16C550 (10x family)", */ 218 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1034, 0, 0 }, 219 { 0xffff, 0xffff, 0, 0 }, 220 { 221 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 222 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 223 { PUC_PORT_TYPE_LPT, 0x20, 0x00 }, 224 }, 225 }, 226 227 /* SIIG Cyber 2S1P PCI 16C650 (10x family): 2S, 1P */ 228 { /* "SIIG Cyber 2S1P PCI 16C650 (10x family)", */ 229 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1035, 0, 0 }, 230 { 0xffff, 0xffff, 0, 0 }, 231 { 232 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 233 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 234 { PUC_PORT_TYPE_LPT, 0x20, 0x00 }, 235 }, 236 }, 237 238 /* SIIG Cyber 2S1P PCI 16C850 (10x family): 2S, 1P */ 239 { /* "SIIG Cyber 2S1P PCI 16C850 (10x family)", */ 240 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1036, 0, 0 }, 241 { 0xffff, 0xffff, 0, 0 }, 242 { 243 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 244 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 245 { PUC_PORT_TYPE_LPT, 0x20, 0x00 }, 246 }, 247 }, 248 249 /* SIIG Cyber 4S PCI 16C550 (10x family): 4S */ 250 { /* "SIIG Cyber 4S PCI 16C550 (10x family)", */ 251 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1050, 0, 0 }, 252 { 0xffff, 0xffff, 0, 0 }, 253 { 254 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 255 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 256 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ }, 257 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ }, 258 }, 259 }, 260 261 /* SIIG Cyber 4S PCI 16C650 (10x family): 4S */ 262 { /* "SIIG Cyber 4S PCI 16C650 (10x family)", */ 263 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1051, 0, 0 }, 264 { 0xffff, 0xffff, 0, 0 }, 265 { 266 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 267 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 268 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ }, 269 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ }, 270 }, 271 }, 272 273 /* SIIG Cyber 4S PCI 16C850 (10x family): 4S */ 274 { /* "SIIG Cyber 4S PCI 16C850 (10x family)", */ 275 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_1052, 0, 0 }, 276 { 0xffff, 0xffff, 0, 0 }, 277 { 278 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 279 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 280 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ }, 281 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ }, 282 }, 283 }, 284 285 /* 286 * SIIG "20x" family boards. 287 */ 288 289 /* SIIG Cyber Parallel PCI (20x family): 1P */ 290 { /* "SIIG Cyber Parallel PCI (20x family)", */ 291 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2020, 0, 0 }, 292 { 0xffff, 0xffff, 0, 0 }, 293 { 294 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 295 }, 296 }, 297 298 /* SIIG Cyber Parallel Dual PCI (20x family): 2P */ 299 { /* "SIIG Cyber Parallel Dual PCI (20x family)", */ 300 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2021, 0, 0 }, 301 { 0xffff, 0xffff, 0, 0 }, 302 { 303 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 304 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 305 }, 306 }, 307 308 /* SIIG Cyber 2P1S PCI 16C550 (20x family): 1S, 2P */ 309 { /* "SIIG Cyber 2P1S PCI 16C550 (20x family)", */ 310 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2040, 0, 0 }, 311 { 0xffff, 0xffff, 0, 0 }, 312 { 313 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 314 { PUC_PORT_TYPE_LPT, 0x14, 0x00 }, 315 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 316 }, 317 }, 318 319 /* SIIG Cyber 2P1S PCI 16C650 (20x family): 1S, 2P */ 320 { /* "SIIG Cyber 2P1S PCI 16C650 (20x family)", */ 321 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2041, 0, 0 }, 322 { 0xffff, 0xffff, 0, 0 }, 323 { 324 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 325 { PUC_PORT_TYPE_LPT, 0x14, 0x00 }, 326 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 327 }, 328 }, 329 330 /* SIIG Cyber 2P1S PCI 16C850 (20x family): 1S, 2P */ 331 { /* "SIIG Cyber 2P1S PCI 16C850 (20x family)", */ 332 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2042, 0, 0 }, 333 { 0xffff, 0xffff, 0, 0 }, 334 { 335 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 336 { PUC_PORT_TYPE_LPT, 0x14, 0x00 }, 337 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 338 }, 339 }, 340 341 /* SIIG Cyber Serial PCI 16C550 (20x family): 1S */ 342 { /* "SIIG Cyber Serial PCI 16C550 (20x family)", */ 343 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2000, 0, 0 }, 344 { 0xffff, 0xffff, 0, 0 }, 345 { 346 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 347 }, 348 }, 349 350 /* SIIG Cyber Serial PCI 16C650 (20x family): 1S */ 351 { /* "SIIG Cyber Serial PCI 16C650 (20x family)", */ 352 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2001, 0, 0 }, 353 { 0xffff, 0xffff, 0, 0 }, 354 { 355 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 356 }, 357 }, 358 359 /* SIIG Cyber Serial PCI 16C850 (20x family): 1S */ 360 { /* "SIIG Cyber Serial PCI 16C850 (20x family)", */ 361 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2002, 0, 0 }, 362 { 0xffff, 0xffff, 0, 0 }, 363 { 364 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 365 }, 366 }, 367 368 /* SIIG Cyber I/O PCI 16C550 (20x family): 1S, 1P */ 369 { /* "SIIG Cyber I/O PCI 16C550 (20x family)", */ 370 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2010, 0, 0 }, 371 { 0xffff, 0xffff, 0, 0 }, 372 { 373 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 374 { PUC_PORT_TYPE_LPT, 0x14, 0x00 }, 375 }, 376 }, 377 378 /* SIIG Cyber I/O PCI 16C650 (20x family): 1S, 1P */ 379 { /* "SIIG Cyber I/O PCI 16C650 (20x family)", */ 380 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2011, 0, 0 }, 381 { 0xffff, 0xffff, 0, 0 }, 382 { 383 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 384 { PUC_PORT_TYPE_LPT, 0x14, 0x00 }, 385 }, 386 }, 387 388 /* SIIG Cyber I/O PCI 16C850 (20x family): 1S, 1P */ 389 { /* "SIIG Cyber I/O PCI 16C850 (20x family)", */ 390 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2012, 0, 0 }, 391 { 0xffff, 0xffff, 0, 0 }, 392 { 393 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 394 { PUC_PORT_TYPE_LPT, 0x14, 0x00 }, 395 }, 396 }, 397 398 /* SIIG Cyber Serial Dual PCI 16C550 (20x family): 2S */ 399 { /* "SIIG Cyber Serial Dual PCI 16C550 (20x family)", */ 400 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2030, 0, 0 }, 401 { 0xffff, 0xffff, 0, 0 }, 402 { 403 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 404 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 405 }, 406 }, 407 408 /* SIIG Cyber Serial Dual PCI 16C650 (20x family): 2S */ 409 { /* "SIIG Cyber Serial Dual PCI 16C650 (20x family)", */ 410 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2031, 0, 0 }, 411 { 0xffff, 0xffff, 0, 0 }, 412 { 413 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 414 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 415 }, 416 }, 417 418 /* SIIG Cyber Serial Dual PCI 16C850 (20x family): 2S */ 419 { /* "SIIG Cyber Serial Dual PCI 16C850 (20x family)", */ 420 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2032, 0, 0 }, 421 { 0xffff, 0xffff, 0, 0 }, 422 { 423 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 424 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 425 }, 426 }, 427 428 /* SIIG Cyber 2S1P PCI 16C550 (20x family): 2S, 1P */ 429 { /* "SIIG Cyber 2S1P PCI 16C550 (20x family)", */ 430 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2060, 0, 0 }, 431 { 0xffff, 0xffff, 0, 0 }, 432 { 433 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 434 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 435 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 436 }, 437 }, 438 439 /* SIIG Cyber 2S1P PCI 16C650 (20x family): 2S, 1P */ 440 { /* "SIIG Cyber 2S1P PCI 16C650 (20x family)", */ 441 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2061, 0, 0 }, 442 { 0xffff, 0xffff, 0, 0 }, 443 { 444 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 445 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 446 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 447 }, 448 }, 449 450 /* SIIG Cyber 2S1P PCI 16C850 (20x family): 2S, 1P */ 451 { /* "SIIG Cyber 2S1P PCI 16C850 (20x family)", */ 452 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2062, 0, 0 }, 453 { 0xffff, 0xffff, 0, 0 }, 454 { 455 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 456 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 457 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 458 }, 459 }, 460 461 /* SIIG Cyber 4S PCI 16C550 (20x family): 4S */ 462 { /* "SIIG Cyber 4S PCI 16C550 (20x family)", */ 463 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2050, 0, 0 }, 464 { 0xffff, 0xffff, 0, 0 }, 465 { 466 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 467 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 468 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 469 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 470 }, 471 }, 472 473 /* SIIG Cyber 4S PCI 16C650 (20x family): 4S */ 474 { /* "SIIG Cyber 4S PCI 16C650 (20x family)", */ 475 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2051, 0, 0 }, 476 { 0xffff, 0xffff, 0, 0 }, 477 { 478 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 479 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 480 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 481 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 482 }, 483 }, 484 485 /* SIIG Cyber 4S PCI 16C850 (20x family): 4S */ 486 { /* "SIIG Cyber 4S PCI 16C850 (20x family)", */ 487 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2052, 0, 0 }, 488 { 0xffff, 0xffff, 0, 0 }, 489 { 490 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 491 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 492 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 493 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 494 }, 495 }, 496 497 /* SIIG Cyber 8S PCI 16C850 (20x family): 8S */ 498 { /* "SIIG Cyber 8S PCI 16C850 (20x family)", */ 499 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_2081, 0, 0 }, 500 { 0xffff, 0xffff, 0, 0 }, 501 { 502 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 503 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 504 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 505 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 506 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ }, 507 { PUC_PORT_TYPE_COM, 0x20, 0x08, COM_FREQ }, 508 { PUC_PORT_TYPE_COM, 0x20, 0x10, COM_FREQ }, 509 { PUC_PORT_TYPE_COM, 0x20, 0x18, COM_FREQ }, 510 }, 511 }, 512 513 /* 514 * VScom PCI-800, as sold on http://www.swann.com.au/isp/titan.html. 515 * Some PLX chip. Note: This board has a software selectable(?) 516 * clock multiplier which this driver doesn't support, so you'll 517 * have to use an appropriately scaled baud rate when talking to 518 * the card. 519 */ 520 { /* "VScom PCI-800", */ 521 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_1076, 0x10b5, 0x1076 }, 522 { 0xffff, 0xffff, 0xffff, 0xffff }, 523 { 524 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 525 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ }, 526 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ }, 527 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ }, 528 { PUC_PORT_TYPE_COM, 0x18, 0x20, COM_FREQ }, 529 { PUC_PORT_TYPE_COM, 0x18, 0x28, COM_FREQ }, 530 { PUC_PORT_TYPE_COM, 0x18, 0x30, COM_FREQ }, 531 { PUC_PORT_TYPE_COM, 0x18, 0x38, COM_FREQ }, 532 }, 533 }, 534 535 /* 536 * Titan PCI-800H. Uses 8 16950 UART, behind a PCI chips that offers 537 * 4 com port on PCI device 0 and 4 on PCI device 1. PCI device 0 has 538 * device ID 3 and PCI device 1 device ID 4. Uses a 14.7456 Mhz crystal 539 * instead of the standart 1.8432Mhz. 540 */ 541 { /* "VScom PCI-800H", */ 542 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800H_0, 0, 0 }, 543 { 0xffff, 0xffff, 0, 0 }, 544 { 545 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 546 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 }, 547 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 }, 548 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 }, 549 }, 550 }, 551 { /* "VScom PCI-800H", */ 552 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800H_1, 0, 0 }, 553 { 0xffff, 0xffff, 0, 0 }, 554 { 555 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 556 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 }, 557 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 }, 558 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 }, 559 }, 560 }, 561 562 /* 563 * VScom PCI-200L has 2 x 16550 UARTS. 564 * The board has a jumper which allows you to select a clock speed 565 * of either 14.7456MHz or 1.8432MHz. By default it runs at the 566 * latter. If pins 2 & 3 are shorted, use COM_FREQ * 8 instead. 567 */ 568 { /* "VScom PCI-200L with 2 x 16550 UARTS" */ 569 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI200L, 0, 0 }, 570 { 0xffff, 0xffff, 0, 0 }, 571 { 572 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 573 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 574 }, 575 }, 576 577 /* NEC PK-UG-X001 K56flex PCI Modem card. 578 NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. */ 579 { /* "NEC PK-UG-X001 K56flex PCI Modem", */ 580 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_MARTH, 0x1033, 0x8014 }, 581 { 0xffff, 0xffff, 0xffff, 0xffff }, 582 { 583 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 584 }, 585 }, 586 587 /*NEC PK-UG-X008 */ 588 { /* "NEC PK-UG-X008", */ 589 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_PKUG, 0x1033, 0x8012 }, 590 { 0xffff, 0xffff, 0xffff, 0xffff }, 591 { 592 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 593 }, 594 }, 595 596 /* Lava Computers 2SP-PCI (0x8000-0x8003) */ 597 { /* "Lava Computers 2SP-PCI parallel port", */ 598 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_1P, 0, 0 }, 599 { 0xffff, 0xfffc, 0, 0 }, 600 { 601 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 602 }, 603 }, 604 605 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */ 606 { /* "Lava Computers dual serial port", */ 607 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_2S, 0, 0 }, 608 { 0xffff, 0xfffc, 0, 0 }, 609 { 610 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 611 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 612 }, 613 }, 614 615 /* Lava Computers LavaPort-Dual and LavaPort-Quad 4*clock PCI serial ports */ 616 { /* "Lava Computers high-speed port", */ 617 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_LAVAPORT_0, 0, 0 }, 618 { 0xffff, 0xfffc, 0, 0 }, 619 { 620 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 }, 621 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ*4 }, 622 }, 623 }, 624 625 /* Lava Computers LavaPort-650 */ 626 { /* "Lava Computers high-speed port", */ 627 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_650, 0, 0 }, 628 { 0xffff, 0xfffc, 0, 0 }, 629 { 630 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 }, 631 }, 632 }, 633 634 /* Koutech IOFLEX-2S PCI Dual Port Serial, port 1 */ 635 { /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 1", */ 636 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_0, 0, 0 }, 637 { 0xffff, 0xfffc, 0, 0 }, 638 { 639 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 640 }, 641 }, 642 643 /* Koutech IOFLEX-2S PCI Dual Port Serial, port 2 */ 644 { /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 2", */ 645 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_1, 0, 0 }, 646 { 0xffff, 0xfffc, 0, 0 }, 647 { 648 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 649 }, 650 }, 651 652 /* Lava Computers Octopus-550 serial ports */ 653 { /* "Lava Computers Octopus-550 8-port serial", */ 654 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_OCTOPUS950_0, 0, 0 }, 655 { 0xffff, 0xfffc, 0, 0 }, 656 { 657 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 658 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 659 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 660 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 661 }, 662 }, 663 664 /* US Robotics (3Com) PCI Modems */ 665 { /* "US Robotics (3Com) 3CP5609 PCI 16550 Modem", */ 666 { PCI_VENDOR_USR, PCI_PRODUCT_USR_3CP5610, 0, 0 }, 667 { 0xffff, 0xffff, 0, 0 }, 668 { 669 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 670 }, 671 }, 672 673 /* IBM 33L4618: AT&T/Lucent Venus Modem */ 674 { /* "IBM 33L4618: AT&T/Lucent Venus Modem", */ 675 /* "Actiontec 56K PCI Master" */ 676 { PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_VENUSMODEM, 0, 0 }, 677 { 0xffff, 0xffff, 0, 0 }, 678 { 679 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ }, 680 }, 681 }, 682 683 /* Topic/SmartLink 5634PCV SurfRider */ 684 { /* "Topic/SmartLink 5634PCV SurfRider", */ 685 /* "Topic/SmartLink 5634PCV SurfRider" */ 686 { PCI_VENDOR_TOPIC, PCI_PRODUCT_TOPIC_5634PCV, 0, 0 }, 687 { 0xffff, 0xffff, 0, 0 }, 688 { 689 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 690 }, 691 }, 692 693 { /* NULL, */ 694 695 { 0, 0, 0, 0 }, 696 { 0, 0, 0, 0 }, 697 { 698 { 0, 0, 0 }, 699 }, 700 } 701 }; 702