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