1 /* $OpenBSD: pucdata.c,v 1.17 2001/11/23 04:18:22 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 * 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, 0x18, 0x00, COM_FREQ * 8 }, 732 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ * 8 }, 733 { PUC_PORT_TYPE_COM, 0x20, 0x08, COM_FREQ * 8 }, 734 { PUC_PORT_TYPE_COM, 0x20, 0x10, COM_FREQ * 8 }, 735 { PUC_PORT_TYPE_COM, 0x20, 0x18, COM_FREQ * 8 }, 736 { PUC_PORT_TYPE_COM, 0x20, 0x20, COM_FREQ * 8 }, 737 { PUC_PORT_TYPE_COM, 0x20, 0x28, COM_FREQ * 8 }, 738 }, 739 }, 740 741 /* 742 * NEC PK-UG-X001 K56flex PCI Modem card. 743 * NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. 744 */ 745 { /* "NEC PK-UG-X001 K56flex PCI Modem", */ 746 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_MARTH, 0x1033, 0x8014 }, 747 { 0xffff, 0xffff, 0xffff, 0xffff }, 748 { 749 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 750 }, 751 }, 752 753 /*NEC PK-UG-X008 */ 754 { /* "NEC PK-UG-X008", */ 755 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_PKUG, 0x1033, 0x8012 }, 756 { 0xffff, 0xffff, 0xffff, 0xffff }, 757 { 758 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 759 }, 760 }, 761 762 /* Lava Computers 2SP-PCI (0x8000-0x8003) */ 763 { /* "Lava Computers 2SP-PCI parallel port", */ 764 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_1P, 0, 0 }, 765 { 0xffff, 0xfffc, 0, 0 }, 766 { 767 { PUC_PORT_TYPE_LPT, 0x10, 0x00 }, 768 }, 769 }, 770 771 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */ 772 { /* "Lava Computers dual serial port", */ 773 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_2S, 0, 0 }, 774 { 0xffff, 0xfffc, 0, 0 }, 775 { 776 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 777 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 778 }, 779 }, 780 781 /* Lava Computers LavaPort-Dual and LavaPort-Quad 4*clock PCI serial ports */ 782 { /* "Lava Computers high-speed port", */ 783 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_LAVAPORT_0, 0, 0 }, 784 { 0xffff, 0xfffc, 0, 0 }, 785 { 786 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 }, 787 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ*4 }, 788 }, 789 }, 790 791 /* Lava Computers LavaPort-650 */ 792 { /* "Lava Computers high-speed port", */ 793 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_650, 0, 0 }, 794 { 0xffff, 0xfffc, 0, 0 }, 795 { 796 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 }, 797 }, 798 }, 799 800 /* Koutech IOFLEX-2S PCI Dual Port Serial, port 1 */ 801 { /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 1", */ 802 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_0, 0, 0 }, 803 { 0xffff, 0xfffc, 0, 0 }, 804 { 805 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 806 }, 807 }, 808 809 /* Koutech IOFLEX-2S PCI Dual Port Serial, port 2 */ 810 { /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 2", */ 811 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_1, 0, 0 }, 812 { 0xffff, 0xfffc, 0, 0 }, 813 { 814 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 815 }, 816 }, 817 818 /* Lava Computers Octopus-550 serial ports */ 819 { /* "Lava Computers Octopus-550 8-port serial", */ 820 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_OCTOPUS550_0, 0, 0 }, 821 { 0xffff, 0xfffc, 0, 0 }, 822 { 823 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 824 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ }, 825 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ }, 826 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ }, 827 }, 828 }, 829 830 /* US Robotics (3Com) PCI Modems */ 831 { /* "US Robotics (3Com) 3CP5609 PCI 16550 Modem", */ 832 { PCI_VENDOR_USR, PCI_PRODUCT_USR_3CP5610, 0, 0 }, 833 { 0xffff, 0xffff, 0, 0 }, 834 { 835 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 836 }, 837 }, 838 839 /* IBM 33L4618: AT&T/Lucent Venus Modem */ 840 { /* "IBM 33L4618: AT&T/Lucent Venus Modem", */ 841 /* "Actiontec 56K PCI Master" */ 842 { PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_VENUSMODEM, 0, 0 }, 843 { 0xffff, 0xffff, 0, 0 }, 844 { 845 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ }, 846 }, 847 }, 848 849 /* Topic/SmartLink 5634PCV SurfRider */ 850 { /* "Topic/SmartLink 5634PCV SurfRider", */ 851 /* "Topic/SmartLink 5634PCV SurfRider" */ 852 { PCI_VENDOR_TOPIC, PCI_PRODUCT_TOPIC_5634PCV, 0, 0 }, 853 { 0xffff, 0xffff, 0, 0 }, 854 { 855 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ }, 856 }, 857 }, 858 859 { /* NULL, */ 860 861 { 0, 0, 0, 0 }, 862 { 0, 0, 0, 0 }, 863 { 864 { 0, 0, 0 }, 865 }, 866 } 867 }; 868