1 /* $OpenBSD: pucdata.c,v 1.30 2003/08/06 22:07:37 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 * VScom PCI 011H, 1 lpt. 537 */ 538 { /* "VScom PCI-011H", */ 539 { PCI_VENDOR_OXFORD2, PCI_PRODUCT_OXFORD2_VSCOM_PCI011H, 0, 0 }, 540 { 0xffff, 0xffff, 0, 0 }, 541 { 542 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 543 }, 544 }, 545 546 /* 547 * VScom PCI x10H, 1 lpt. 548 * is the lpt part of VScom 110H, 210H, 410H 549 */ 550 { /* "VScom PCI-x10H", */ 551 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCIx10H, 0, 0 }, 552 { 0xffff, 0xffff, 0, 0 }, 553 { 554 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 555 }, 556 }, 557 558 /* 559 * VScom PCI 100H, little sister of 800H, 1 com. 560 * also com part of VScom 110H 561 * The one I have defaults to a fequency of 14.7456 MHz which is 562 * jumper J1 set to 2-3. 563 */ 564 { /* "VScom PCI-100H", */ 565 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI100H, 0, 0 }, 566 { 0xffff, 0xffff, 0, 0 }, 567 { 568 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 569 }, 570 }, 571 572 /* 573 * VScom PCI 200H, little sister of 800H, 2 com. 574 * also com part of VScom 210H 575 * The one I have defaults to a fequency of 14.7456 MHz which is 576 * jumper J1 set to 2-3. 577 */ 578 579 { /* "VScom PCI-200H", */ 580 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI200H, 0, 0 }, 581 { 0xffff, 0xffff, 0, 0 }, 582 { 583 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 584 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 }, 585 }, 586 }, 587 588 /* 589 * VScom PCI 400H and 800H. Uses 4/8 16950 UART, behind a PCI chips 590 * that offers 4 com port on PCI device 0 (both 400H and 800H) 591 * and 4 on PCI device 1 (800H only). PCI device 0 has 592 * device ID 3 and PCI device 1 device ID 4. Uses a 14.7456 MHz crystal 593 * instead of the standart 1.8432MHz. 594 * There's a version with a jumper for selecting the crystal frequency, 595 * defaults to 8x as used here. The jumperless version uses 8x, too. 596 */ 597 { /* "VScom PCI-400H/800H", */ 598 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800H_0, 0, 0 }, 599 { 0xffff, 0xffff, 0, 0 }, 600 { 601 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 602 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 }, 603 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 }, 604 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 }, 605 }, 606 }, 607 { /* "VScom PCI-400H/800H", */ 608 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800H_1, 0, 0 }, 609 { 0xffff, 0xffff, 0, 0 }, 610 { 611 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 612 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 }, 613 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 }, 614 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 }, 615 }, 616 }, 617 618 /* 619 * VScom PCI 200HV2, is 200H Version 2. 620 * Sells as 200H 621 */ 622 { /* "VScom PCI-200HV2", */ 623 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI200HV2, 0, 0 }, 624 { 0xffff, 0xffff, 0, 0 }, 625 { 626 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 }, 627 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8 }, 628 }, 629 }, 630 631 /* 632 * VScom PCI 010L 633 * one lpt 634 * untested 635 */ 636 { /* "VScom PCI-010L", */ 637 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI010L, 0, 0 }, 638 { 0xffff, 0xffff, 0, 0 }, 639 { 640 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 641 }, 642 }, 643 644 /* 645 * VScom PCI 100L 646 * one com 647 * The one I have defaults to a fequency of 14.7456 MHz which is 648 * jumper J1 set to 2-3. 649 */ 650 { /* "VScom PCI-100L", */ 651 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI100L, 0, 0 }, 652 { 0xffff, 0xffff, 0, 0 }, 653 { 654 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8 }, 655 }, 656 }, 657 658 /* 659 * VScom PCI 110L 660 * one com, one lpt 661 * untested 662 */ 663 { /* "VScom PCI-110L", */ 664 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI110L, 0, 0 }, 665 { 0xffff, 0xffff, 0, 0 }, 666 { 667 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8 }, 668 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 669 }, 670 }, 671 672 /* 673 * VScom PCI-200L has 2 x 16550 UARTS. 674 * The board has a jumper which allows you to select a clock speed 675 * of either 14.7456MHz or 1.8432MHz. By default it runs at 676 * the fast speed. 677 */ 678 { /* "VScom PCI-200L with 2 x 16550 UARTS" */ 679 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI200L, 0, 0 }, 680 { 0xffff, 0xffff, 0, 0 }, 681 { 682 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8}, 683 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8}, 684 }, 685 }, 686 687 /* 688 * VScom PCI-210L 689 * Has a jumper for frequency selection, defaults to 8x as used here 690 * two com, one lpt 691 */ 692 { /* "VScom PCI-210L" */ 693 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI210L, 0, 0 }, 694 { 0xffff, 0xffff, 0, 0 }, 695 { 696 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8 }, 697 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 }, 698 { PUC_PORT_TYPE_LPT, 0x1c, 0x00 }, 699 }, 700 }, 701 702 /* 703 * VScom PCI 400L 704 * Has a jumper for frequency selection, defaults to 8x as used here 705 * This is equal to J1 in pos 2-3 706 * VendorID mismatch with docs, should be 14d2 (oxford), is 10d2 (molex) 707 */ 708 { /* "VScom PCI-400L", */ 709 { PCI_VENDOR_MOLEX, PCI_PRODUCT_MOLEX_VSCOM_PCI400L, 0, 0 }, 710 { 0xffff, 0xffff, 0, 0 }, 711 { 712 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8 }, 713 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 }, 714 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ * 8 }, 715 { PUC_PORT_TYPE_COM, 0x20, 0x08, COM_FREQ * 8 }, 716 }, 717 }, 718 719 /* 720 * VScom PCI 800L 721 * Has a jumper for frequency selection, defaults to 8x as used here 722 */ 723 { /* "VScom PCI-800L", */ 724 { PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800L, 0, 0 }, 725 { 0xffff, 0xffff, 0, 0 }, 726 { 727 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8 }, 728 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 }, 729 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ * 8 }, 730 { PUC_PORT_TYPE_COM, 0x20, 0x08, COM_FREQ * 8 }, 731 { PUC_PORT_TYPE_COM, 0x20, 0x10, COM_FREQ * 8 }, 732 { PUC_PORT_TYPE_COM, 0x20, 0x18, COM_FREQ * 8 }, 733 { PUC_PORT_TYPE_COM, 0x20, 0x20, COM_FREQ * 8 }, 734 { PUC_PORT_TYPE_COM, 0x20, 0x28, COM_FREQ * 8 }, 735 }, 736 }, 737 738 /* 739 * NEC PK-UG-X001 K56flex PCI Modem card. 740 * NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. 741 */ 742 { /* "NEC PK-UG-X001 K56flex PCI Modem", */ 743 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_MARTH, 0x1033, 0x8014 }, 744 { 0xffff, 0xffff, 0xffff, 0xffff }, 745 { 746 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 747 }, 748 }, 749 750 /* NEC PK-UG-X008 */ 751 { /* "NEC PK-UG-X008", */ 752 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_PKUG, 0x1033, 0x8012 }, 753 { 0xffff, 0xffff, 0xffff, 0xffff }, 754 { 755 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 756 }, 757 }, 758 759 /* Lava Computers 2SP-PCI (0x8000-0x8003) */ 760 { /* "Lava Computers 2SP-PCI parallel port", */ 761 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_1P, 0, 0 }, 762 { 0xffff, 0xfffc, 0, 0 }, 763 { 764 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 765 }, 766 }, 767 768 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */ 769 { /* "Lava Computers dual serial port", */ 770 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_2S, 0, 0 }, 771 { 0xffff, 0xfffc, 0, 0 }, 772 { 773 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 774 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 775 }, 776 }, 777 778 /* 779 * Lava Computers Quattro-PCI serial ports. 780 * A second version of the Quattro-PCI with different PCI ids. 781 */ 782 { /* "Lava Computers Quattro-PCI 4-port serial", */ 783 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_AB2, 0, 0 }, 784 { 0xffff, 0xfffe, 0, 0 }, 785 { 786 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 787 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 788 }, 789 }, 790 791 /* 792 * Lava Computers LavaPort-Dual and LavaPort-Quad 4*clock PCI 793 * serial ports. 794 */ 795 { /* "Lava Computers high-speed port", */ 796 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_LAVAPORT_0, 0, 0 }, 797 { 0xffff, 0xfffc, 0, 0 }, 798 { 799 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 }, 800 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ*4 }, 801 }, 802 }, 803 804 /* Lava Computers LavaPort-650 */ 805 { /* "Lava Computers high-speed port", */ 806 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_650, 0, 0 }, 807 { 0xffff, 0xfffc, 0, 0 }, 808 { 809 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 }, 810 }, 811 }, 812 813 /* Koutech IOFLEX-2S PCI Dual Port Serial, port 1 */ 814 { /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 1", */ 815 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_0, 0, 0 }, 816 { 0xffff, 0xfffc, 0, 0 }, 817 { 818 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 819 }, 820 }, 821 822 /* Koutech IOFLEX-2S PCI Dual Port Serial, port 2 */ 823 { /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 2", */ 824 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_1, 0, 0 }, 825 { 0xffff, 0xfffc, 0, 0 }, 826 { 827 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 828 }, 829 }, 830 831 /* Lava Computers Octopus-550 serial ports */ 832 { /* "Lava Computers Octopus-550 8-port serial", */ 833 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_OCTOPUS550_0, 0, 0 }, 834 { 0xffff, 0xfffc, 0, 0 }, 835 { 836 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 837 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 838 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 839 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 840 }, 841 }, 842 843 /* US Robotics (3Com) PCI Modems */ 844 { /* "US Robotics (3Com) 3CP5610 PCI 16550 Modem", */ 845 { PCI_VENDOR_USR, PCI_PRODUCT_USR_3CP5610, 0, 0 }, 846 { 0xffff, 0xffff, 0, 0 }, 847 { 848 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 849 }, 850 }, 851 852 /* IBM 33L4618: AT&T/Lucent Venus Modem */ 853 { /* "IBM 33L4618: AT&T/Lucent Venus Modem", */ 854 /* "Actiontec 56K PCI Master" */ 855 { PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_VENUSMODEM, 0, 0 }, 856 { 0xffff, 0xffff, 0, 0 }, 857 { 858 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ }, 859 }, 860 }, 861 862 /* Topic/SmartLink 5634PCV SurfRider */ 863 { /* "Topic/SmartLink 5634PCV SurfRider" */ 864 { PCI_VENDOR_TOPIC, PCI_PRODUCT_TOPIC_5634PCV, 0, 0 }, 865 { 0xffff, 0xffff, 0, 0 }, 866 { 867 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 868 }, 869 }, 870 871 /* SD-LAB PCI I/O Card 4S2P */ 872 { /* "Syba Tech Ltd. PCI-4S2P-550-ECP" */ 873 { PCI_VENDOR_SYBA, PCI_PRODUCT_SYBA_4S2P, 0, 0 }, 874 { 0xffff, 0xffff, 0, 0 }, 875 { 876 { PUC_PORT_TYPE_COM, 0x10, 0x2e8, COM_FREQ }, 877 { PUC_PORT_TYPE_COM, 0x10, 0x2f8, COM_FREQ }, 878 { PUC_PORT_TYPE_LPT, 0x10, 0x000, 0x00 }, 879 { PUC_PORT_TYPE_COM, 0x10, 0x3e8, COM_FREQ }, 880 { PUC_PORT_TYPE_COM, 0x10, 0x3f8, COM_FREQ }, 881 { PUC_PORT_TYPE_LPT, 0x10, 0x000, 0x00 }, 882 }, 883 }, 884 885 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */ 886 { /* "Moxa Technologies, Industio CP-114" */ 887 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_CP114, 0, 0 }, 888 { 0xffff, 0xffff, 0, 0 }, 889 { 890 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 }, 891 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 }, 892 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 }, 893 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 }, 894 }, 895 }, 896 897 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */ 898 { /* "Moxa Technologies, SmartIO C104H/PCI" */ 899 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C104H, 0, 0 }, 900 { 0xffff, 0xffff, 0, 0 }, 901 { 902 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 }, 903 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 }, 904 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 }, 905 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 }, 906 }, 907 }, 908 909 /* Moxa Technologies Co., Ltd. PCI I/O Card 8S RS232 */ 910 { /* "Moxa Technologies, Industio C168H" */ 911 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C168H, 0, 0 }, 912 { 0xffff, 0xffff, 0, 0 }, 913 { 914 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 }, 915 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 }, 916 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 }, 917 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 }, 918 { PUC_PORT_TYPE_COM, 0x18, 0x20, COM_FREQ * 8 }, 919 { PUC_PORT_TYPE_COM, 0x18, 0x28, COM_FREQ * 8 }, 920 { PUC_PORT_TYPE_COM, 0x18, 0x30, COM_FREQ * 8 }, 921 { PUC_PORT_TYPE_COM, 0x18, 0x38, COM_FREQ * 8 }, 922 }, 923 }, 924 925 /* NetMos 2S1P PCI 16C650 : 2S, 1P */ 926 { /* "NetMos NM9835 Dual UART and 1284 Printer port" */ 927 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_2S1P, 0, 0 }, 928 { 0xffff, 0xffff, 0, 0 }, 929 { 930 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 931 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 932 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 }, 933 }, 934 }, 935 936 { /* Sunix 4018A : 2-port parallel */ 937 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_4018A, 0, 0 }, 938 { 0xffff, 0xffff, 0, 0 }, 939 { 940 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 941 { PUC_PORT_TYPE_LPT, 0x18, 0x00 }, 942 }, 943 }, 944 945 /* 946 * SUNIX 40XX series of serial/parallel combo cards. 947 * Tested with 4055A and 4065A. 948 */ 949 { /* SUNIX 400X 1P */ 950 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4000 }, 951 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 952 { 953 { PUC_PORT_TYPE_LPT, 0x10, 0x00, 0x00 }, 954 }, 955 }, 956 957 { /* SUNIX 401X 2P */ 958 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4010 }, 959 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 960 { 961 { PUC_PORT_TYPE_LPT, 0x10, 0x00, 0x00 }, 962 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 }, 963 }, 964 }, 965 966 { /* SUNIX 402X 1S */ 967 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4020 }, 968 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 969 { 970 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 971 }, 972 }, 973 974 { /* SUNIX 403X 2S */ 975 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4030 }, 976 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 977 { 978 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 979 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8}, 980 }, 981 }, 982 983 { /* SUNIX 405X 4S */ 984 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4050 }, 985 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 986 { 987 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 988 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8}, 989 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ}, 990 { PUC_PORT_TYPE_COM, 0x14, 0x08, COM_FREQ}, 991 }, 992 }, 993 994 { /* SUNIX 406X 8S */ 995 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4060 }, 996 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 997 { 998 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 999 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8}, 1000 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ}, 1001 { PUC_PORT_TYPE_COM, 0x14, 0x08, COM_FREQ}, 1002 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ}, 1003 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ}, 1004 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ}, 1005 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ}, 1006 }, 1007 }, 1008 1009 { /* SUNIX 407X 2S/1P */ 1010 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4070 }, 1011 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 1012 { 1013 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 1014 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8}, 1015 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 }, 1016 }, 1017 }, 1018 1019 { /* SUNIX 408X 2S/2P */ 1020 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4080 }, 1021 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 1022 { 1023 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 1024 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8}, 1025 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 }, 1026 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 }, 1027 }, 1028 }, 1029 1030 { /* SUNIX 409X 4S/2P */ 1031 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_40XX, 0x1409, 0x4090 }, 1032 { 0xffff, 0xffff, 0xffff, 0xeff0 }, 1033 { 1034 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8}, 1035 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8}, 1036 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ}, 1037 { PUC_PORT_TYPE_COM, 0x14, 0x08, COM_FREQ}, 1038 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 }, 1039 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 }, 1040 }, 1041 }, 1042 1043 /* 1044 * Boca Research Turbo Serial 654 (4 serial port) card. 1045 * Appears to be the same as Chase Research PLC PCI-FAST4 card, 1046 * same as Perle PCI-FAST4 Multi-Port serial card 1047 */ 1048 { /* "Boca Turbo Serial 654 - IOP654" */ 1049 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x12e0, 0x0031 }, 1050 { 0xffff, 0xffff, 0xffff, 0xffff }, 1051 { 1052 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 4 }, 1053 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 4 }, 1054 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 4 }, 1055 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 4 }, 1056 }, 1057 }, 1058 1059 /* 1060 * Boca Research Turbo Serial 658 (8 serial port) card. 1061 * Appears to be the same as Chase Research PLC PCI-FAST8 card 1062 * same as Perle PCI-FAST8 Multi-Port serial card 1063 */ 1064 { /* "Boca Turbo Serial 658 - IOP658" */ 1065 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x12e0, 0x0021 }, 1066 { 0xffff, 0xffff, 0xffff, 0xffff }, 1067 { 1068 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 4 }, 1069 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 4 }, 1070 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 4 }, 1071 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 4 }, 1072 { PUC_PORT_TYPE_COM, 0x18, 0x20, COM_FREQ * 4 }, 1073 { PUC_PORT_TYPE_COM, 0x18, 0x28, COM_FREQ * 4 }, 1074 { PUC_PORT_TYPE_COM, 0x18, 0x30, COM_FREQ * 4 }, 1075 { PUC_PORT_TYPE_COM, 0x18, 0x38, COM_FREQ * 4 }, 1076 }, 1077 }, 1078 1079 { /* NULL, */ 1080 1081 { 0, 0, 0, 0 }, 1082 { 0, 0, 0, 0 }, 1083 { 1084 { 0, 0, 0 }, 1085 }, 1086 } 1087 }; 1088