1 /* $NetBSD: pucdata.c,v 1.25 2001/12/16 22:23:01 thorpej Exp $ */
4 * Copyright (c) 1998, 1999 Christopher G. Demetriou. All rights reserved.
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * 3. All advertising materials mentioning features or use of this software
15 * must display the following acknowledgement:
16 * This product includes software developed by Christopher G. Demetriou
17 * for the NetBSD Project.
18 * 4. The name of the author may not be used to endorse or promote products
19 * derived from this software without specific prior written permission
21 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 #include <sys/cdefs.h>
34 __FBSDID("$FreeBSD$");
37 * PCI "universal" communications card driver configuration data (used to
38 * match/attach the cards).
41 #include <sys/param.h>
43 #include <dev/pci/pcireg.h>
44 #include <dev/pci/pcivar.h>
45 #include <dev/sio/sioreg.h>
46 #include <dev/puc/pucvar.h>
48 #define COM_FREQ DEFAULT_RCLK
50 const struct puc_device_description puc_devices[] = {
52 { "Comtrol RocketPort 550/4 RJ45",
54 { 0x11fe, 0x8014, 0, 0 },
55 { 0xffff, 0xffff, 0, 0 },
57 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
58 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
59 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
60 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
64 { "Comtrol RocketPort 550/Quad",
66 { 0x11fe, 0x8015, 0, 0 },
67 { 0xffff, 0xffff, 0, 0 },
69 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
70 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
71 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
72 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
76 { "Comtrol RocketPort 550/8 RJ11 part A",
78 { 0x11fe, 0x8010, 0, 0 },
79 { 0xffff, 0xffff, 0, 0 },
81 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
82 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
83 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
84 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
87 { "Comtrol RocketPort 550/8 RJ11 part B",
89 { 0x11fe, 0x8011, 0, 0 },
90 { 0xffff, 0xffff, 0, 0 },
92 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
93 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
94 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
95 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
99 { "Comtrol RocketPort 550/8 Octa part A",
101 { 0x11fe, 0x8012, 0, 0 },
102 { 0xffff, 0xffff, 0, 0 },
104 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
105 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
106 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
107 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
110 { "Comtrol RocketPort 550/8 Octa part B",
112 { 0x11fe, 0x8013, 0, 0 },
113 { 0xffff, 0xffff, 0, 0 },
115 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
116 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
117 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
118 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
122 { "Comtrol RocketPort 550/8 part A",
124 { 0x11fe, 0x8018, 0, 0 },
125 { 0xffff, 0xffff, 0, 0 },
127 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
128 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
129 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
130 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
133 { "Comtrol RocketPort 550/8 part B",
135 { 0x11fe, 0x8019, 0, 0 },
136 { 0xffff, 0xffff, 0, 0 },
138 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
139 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
140 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
141 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
145 { "Comtrol RocketPort 550/16 part A",
147 { 0x11fe, 0x8016, 0, 0 },
148 { 0xffff, 0xffff, 0, 0 },
150 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
151 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
152 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
153 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
156 { "Comtrol RocketPort 550/16 part B",
158 { 0x11fe, 0x8017, 0, 0 },
159 { 0xffff, 0xffff, 0, 0 },
161 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 4 },
162 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 4 },
163 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 4 },
164 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 4 },
165 { PUC_PORT_TYPE_COM, 0x10, 0x20, COM_FREQ * 4 },
166 { PUC_PORT_TYPE_COM, 0x10, 0x28, COM_FREQ * 4 },
167 { PUC_PORT_TYPE_COM, 0x10, 0x30, COM_FREQ * 4 },
168 { PUC_PORT_TYPE_COM, 0x10, 0x38, COM_FREQ * 4 },
169 { PUC_PORT_TYPE_COM, 0x10, 0x40, COM_FREQ * 4 },
170 { PUC_PORT_TYPE_COM, 0x10, 0x48, COM_FREQ * 4 },
171 { PUC_PORT_TYPE_COM, 0x10, 0x50, COM_FREQ * 4 },
172 { PUC_PORT_TYPE_COM, 0x10, 0x58, COM_FREQ * 4 },
177 * XXX no entry because I have no data:
178 * XXX Dolphin Peripherals 4006 (single parallel)
182 * Dolphin Peripherals 4014 (dual parallel port) card. PLX 9050, with
183 * a seemingly-lame EEPROM setup that puts the Dolphin IDs
184 * into the subsystem fields, and claims that it's a
185 * network/misc (0x02/0x80) device.
187 { "Dolphin Peripherals 4014",
189 { 0x10b5, 0x9050, 0xd84d, 0x6810 },
190 { 0xffff, 0xffff, 0xffff, 0xffff },
192 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 },
193 { PUC_PORT_TYPE_LPT, 0x24, 0x00, 0x00 },
198 * XXX Dolphin Peripherals 4025 (single serial)
199 * (clashes with Dolphin Peripherals 4036 (2s variant)
203 * Dolphin Peripherals 4035 (dual serial port) card. PLX 9050, with
204 * a seemingly-lame EEPROM setup that puts the Dolphin IDs
205 * into the subsystem fields, and claims that it's a
206 * network/misc (0x02/0x80) device.
208 { "Dolphin Peripherals 4035",
210 { 0x10b5, 0x9050, 0xd84d, 0x6808 },
211 { 0xffff, 0xffff, 0xffff, 0xffff },
213 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
214 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
219 * Dolphin Peripherals 4036 (dual serial port) card.
220 * (Dolpin 4025 has the same ID but only one port)
222 { "Dolphin Peripherals 4036",
224 { 0x1409, 0x7168, 0x0, 0x0 },
225 { 0xffff, 0xffff, 0x0, 0x0 },
227 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8},
228 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8},
233 * XXX no entry because I have no data:
234 * XXX Dolphin Peripherals 4078 (dual serial and single parallel)
241 * SIIG provides documentation for their boards at:
242 * <URL:http://www.siig.com/driver.htm>
244 * Please excuse the weird ordering, it's the order they
245 * use in their documentation.
249 * SIIG "10x" family boards.
252 /* SIIG Cyber Serial PCI 16C550 (10x family): 1S */
253 { "SIIG Cyber Serial PCI 16C550 (10x family)",
255 { 0x131f, 0x1000, 0, 0 },
256 { 0xffff, 0xffff, 0, 0 },
258 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
262 /* SIIG Cyber Serial PCI 16C650 (10x family): 1S */
263 { "SIIG Cyber Serial PCI 16C650 (10x family)",
265 { 0x131f, 0x1001, 0, 0 },
266 { 0xffff, 0xffff, 0, 0 },
268 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
272 /* SIIG Cyber Serial PCI 16C850 (10x family): 1S */
273 { "SIIG Cyber Serial PCI 16C850 (10x family)",
275 { 0x131f, 0x1002, 0, 0 },
276 { 0xffff, 0xffff, 0, 0 },
278 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
282 /* SIIG Cyber I/O PCI 16C550 (10x family): 1S, 1P */
283 { "SIIG Cyber I/O PCI 16C550 (10x family)",
285 { 0x131f, 0x1010, 0, 0 },
286 { 0xffff, 0xffff, 0, 0 },
288 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
289 { PUC_PORT_TYPE_LPT, 0x1c, 0x00, 0x00 },
293 /* SIIG Cyber I/O PCI 16C650 (10x family): 1S, 1P */
294 { "SIIG Cyber I/O PCI 16C650 (10x family)",
296 { 0x131f, 0x1011, 0, 0 },
297 { 0xffff, 0xffff, 0, 0 },
299 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
300 { PUC_PORT_TYPE_LPT, 0x1c, 0x00, 0x00 },
304 /* SIIG Cyber I/O PCI 16C850 (10x family): 1S, 1P */
305 { "SIIG Cyber I/O PCI 16C850 (10x family)",
307 { 0x131f, 0x1012, 0, 0 },
308 { 0xffff, 0xffff, 0, 0 },
310 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
311 { PUC_PORT_TYPE_LPT, 0x1c, 0x00, 0x00 },
315 /* SIIG Cyber Parallel PCI (10x family): 1P */
316 { "SIIG Cyber Parallel PCI (10x family)",
318 { 0x131f, 0x1020, 0, 0 },
319 { 0xffff, 0xffff, 0, 0 },
321 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
325 /* SIIG Cyber Parallel Dual PCI (10x family): 2P */
326 { "SIIG Cyber Parallel Dual PCI (10x family)",
328 { 0x131f, 0x1021, 0, 0 },
329 { 0xffff, 0xffff, 0, 0 },
331 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
332 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 },
336 /* SIIG Cyber Serial Dual PCI 16C550 (10x family): 2S */
337 { "SIIG Cyber Serial Dual PCI 16C550 (10x family)",
339 { 0x131f, 0x1030, 0, 0 },
340 { 0xffff, 0xffff, 0, 0 },
342 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
343 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
347 /* SIIG Cyber Serial Dual PCI 16C650 (10x family): 2S */
348 { "SIIG Cyber Serial Dual PCI 16C650 (10x family)",
350 { 0x131f, 0x1031, 0, 0 },
351 { 0xffff, 0xffff, 0, 0 },
353 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
354 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
358 /* SIIG Cyber Serial Dual PCI 16C850 (10x family): 2S */
359 { "SIIG Cyber Serial Dual PCI 16C850 (10x family)",
361 { 0x131f, 0x1032, 0, 0 },
362 { 0xffff, 0xffff, 0, 0 },
364 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
365 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
369 /* SIIG Cyber 2S1P PCI 16C550 (10x family): 2S, 1P */
370 { "SIIG Cyber 2S1P PCI 16C550 (10x family)",
372 { 0x131f, 0x1034, 0, 0 }, /* XXX really? */
373 { 0xffff, 0xffff, 0, 0 },
375 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
376 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
377 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 },
381 /* SIIG Cyber 2S1P PCI 16C650 (10x family): 2S, 1P */
382 { "SIIG Cyber 2S1P PCI 16C650 (10x family)",
384 { 0x131f, 0x1035, 0, 0 }, /* XXX really? */
385 { 0xffff, 0xffff, 0, 0 },
387 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
388 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
389 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 },
393 /* SIIG Cyber 2S1P PCI 16C850 (10x family): 2S, 1P */
394 { "SIIG Cyber 2S1P PCI 16C850 (10x family)",
396 { 0x131f, 0x1036, 0, 0 }, /* XXX really? */
397 { 0xffff, 0xffff, 0, 0 },
399 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
400 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
401 { PUC_PORT_TYPE_LPT, 0x20, 0x00, 0x00 },
405 /* SIIG Cyber 4S PCI 16C550 (10x family): 4S */
406 { "SIIG Cyber 4S PCI 16C550 (10x family)",
408 { 0x131f, 0x1050, 0, 0 },
409 { 0xffff, 0xffff, 0, 0 },
411 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
412 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
413 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ },
414 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ },
418 /* SIIG Cyber 4S PCI 16C650 (10x family): 4S */
419 { "SIIG Cyber 4S PCI 16C650 (10x family)",
421 { 0x131f, 0x1051, 0, 0 },
422 { 0xffff, 0xffff, 0, 0 },
424 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
425 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
426 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ },
427 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ },
431 /* SIIG Cyber 4S PCI 16C850 (10x family): 4S */
432 { "SIIG Cyber 4S PCI 16C850 (10x family)",
434 { 0x131f, 0x1052, 0, 0 },
435 { 0xffff, 0xffff, 0, 0 },
437 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
438 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
439 { PUC_PORT_TYPE_COM, 0x20, 0x00, COM_FREQ },
440 { PUC_PORT_TYPE_COM, 0x24, 0x00, COM_FREQ },
445 * SIIG "20x" family boards.
448 /* SIIG Cyber Parallel PCI (20x family): 1P */
449 { "SIIG Cyber Parallel PCI (20x family)",
451 { 0x131f, 0x2020, 0, 0 },
452 { 0xffff, 0xffff, 0, 0 },
454 { PUC_PORT_TYPE_LPT, 0x10, 0x00, 0x00 },
458 /* SIIG Cyber Parallel Dual PCI (20x family): 2P */
459 { "SIIG Cyber Parallel Dual PCI (20x family)",
461 { 0x131f, 0x2021, 0, 0 },
462 { 0xffff, 0xffff, 0, 0 },
464 { PUC_PORT_TYPE_LPT, 0x10, 0x00, 0x00 },
465 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
469 /* SIIG Cyber 2P1S PCI 16C550 (20x family): 1S, 2P */
470 { "SIIG Cyber 2P1S PCI 16C550 (20x family)",
472 { 0x131f, 0x2040, 0, 0 },
473 { 0xffff, 0xffff, 0, 0 },
475 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
476 { PUC_PORT_TYPE_LPT, 0x14, 0x00, 0x00 },
477 { PUC_PORT_TYPE_LPT, 0x1c, 0x00, 0x00 },
481 /* SIIG Cyber 2P1S PCI 16C650 (20x family): 1S, 2P */
482 { "SIIG Cyber 2P1S PCI 16C650 (20x family)",
484 { 0x131f, 0x2041, 0, 0 },
485 { 0xffff, 0xffff, 0, 0 },
487 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
488 { PUC_PORT_TYPE_LPT, 0x14, 0x00, 0x00 },
489 { PUC_PORT_TYPE_LPT, 0x1c, 0x00, 0x00 },
493 /* SIIG Cyber 2P1S PCI 16C850 (20x family): 1S, 2P */
494 { "SIIG Cyber 2P1S PCI 16C850 (20x family)",
496 { 0x131f, 0x2042, 0, 0 },
497 { 0xffff, 0xffff, 0, 0 },
499 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
500 { PUC_PORT_TYPE_LPT, 0x14, 0x00, 0x00 },
501 { PUC_PORT_TYPE_LPT, 0x1c, 0x00, 0x00 },
505 /* SIIG Cyber Serial PCI 16C550 (20x family): 1S */
506 { "SIIG Cyber Serial PCI 16C550 (20x family)",
508 { 0x131f, 0x2000, 0, 0 },
509 { 0xffff, 0xffff, 0, 0 },
511 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
515 /* SIIG Cyber Serial PCI 16C650 (20x family): 1S */
516 { "SIIG Cyber Serial PCI 16C650 (20x family)",
518 { 0x131f, 0x2001, 0, 0 },
519 { 0xffff, 0xffff, 0, 0 },
521 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
525 /* SIIG Cyber Serial PCI 16C850 (20x family): 1S */
526 { "SIIG Cyber Serial PCI 16C850 (20x family)",
528 { 0x131f, 0x2002, 0, 0 },
529 { 0xffff, 0xffff, 0, 0 },
531 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
535 /* SIIG Cyber I/O PCI 16C550 (20x family): 1S, 1P */
536 { "SIIG Cyber I/O PCI 16C550 (20x family)",
538 { 0x131f, 0x2010, 0, 0 },
539 { 0xffff, 0xffff, 0, 0 },
541 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
542 { PUC_PORT_TYPE_LPT, 0x14, 0x00, 0x00 },
546 /* SIIG Cyber I/O PCI 16C650 (20x family): 1S, 1P */
547 { "SIIG Cyber I/O PCI 16C650 (20x family)",
549 { 0x131f, 0x2011, 0, 0 },
550 { 0xffff, 0xffff, 0, 0 },
552 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
553 { PUC_PORT_TYPE_LPT, 0x14, 0x00, 0x00 },
557 /* SIIG Cyber I/O PCI 16C850 (20x family): 1S, 1P */
558 { "SIIG Cyber I/O PCI 16C850 (20x family)",
560 { 0x131f, 0x2012, 0, 0 },
561 { 0xffff, 0xffff, 0, 0 },
563 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
564 { PUC_PORT_TYPE_LPT, 0x14, 0x00, 0x00 },
568 /* SIIG Cyber Serial Dual PCI 16C550 (20x family): 2S */
569 { "SIIG Cyber Serial Dual PCI 16C550 (20x family)",
571 { 0x131f, 0x2030, 0, 0 },
572 { 0xffff, 0xffff, 0, 0 },
574 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
575 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
579 /* SIIG Cyber Serial Dual PCI 16C650 (20x family): 2S */
580 { "SIIG Cyber Serial Dual PCI 16C650 (20x family)",
582 { 0x131f, 0x2031, 0, 0 },
583 { 0xffff, 0xffff, 0, 0 },
585 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
586 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
590 /* SIIG Cyber Serial Dual PCI 16C850 (20x family): 2S */
591 { "SIIG Cyber Serial Dual PCI 16C850 (20x family)",
593 { 0x131f, 0x2032, 0, 0 },
594 { 0xffff, 0xffff, 0, 0 },
596 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
597 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
601 /* SIIG Cyber 2S1P PCI 16C550 (20x family): 2S, 1P */
602 { "SIIG Cyber 2S1P PCI 16C550 (20x family)",
604 { 0x131f, 0x2060, 0, 0 },
605 { 0xffff, 0xffff, 0, 0 },
607 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
608 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
609 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
613 /* SIIG Cyber 2S1P PCI 16C650 (20x family): 2S, 1P */
614 { "SIIG Cyber 2S1P PCI 16C650 (20x family)",
616 { 0x131f, 0x2061, 0, 0 },
617 { 0xffff, 0xffff, 0, 0 },
619 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
620 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
621 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
625 /* SIIG Cyber 2S1P PCI 16C850 (20x family): 2S, 1P */
626 { "SIIG Cyber 2S1P PCI 16C850 (20x family)",
628 { 0x131f, 0x2062, 0, 0 },
629 { 0xffff, 0xffff, 0, 0 },
631 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
632 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
633 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
637 /* SIIG Cyber 4S PCI 16C550 (20x family): 4S */
638 { "SIIG Cyber 4S PCI 16C550 (20x family)",
640 { 0x131f, 0x2050, 0, 0 },
641 { 0xffff, 0xffff, 0, 0 },
643 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
644 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
645 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
646 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
650 /* SIIG Cyber 4S PCI 16C650 (20x family): 4S */
651 { "SIIG Cyber 4S PCI 16C650 (20x family)",
653 { 0x131f, 0x2051, 0, 0 },
654 { 0xffff, 0xffff, 0, 0 },
656 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
657 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
658 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
659 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
663 /* SIIG Cyber 4S PCI 16C850 (20x family): 4S */
664 { "SIIG Cyber 4S PCI 16C850 (20x family)",
666 { 0x131f, 0x2052, 0, 0 },
667 { 0xffff, 0xffff, 0, 0 },
669 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
670 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
671 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
672 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
676 /* VScom PCI-200L: 2S */
679 { 0x14d2, 0x8020, 0, 0 },
680 { 0xffff, 0xffff, 0, 0 },
682 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ * 8},
683 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8},
687 /* VScom PCI-400: 4S */
690 { 0x10b5, 0x1077, 0x10b5, 0x1077 },
691 { 0xffff, 0xffff, 0xffff, 0xffff },
693 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 },
694 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 },
695 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 },
696 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 },
700 /* VScom PCI-800: 8S */
703 { 0x10b5, 0x1076, 0x10b5, 0x1076 },
704 { 0xffff, 0xffff, 0xffff, 0xffff },
706 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 },
707 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 },
708 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 },
709 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 },
710 { PUC_PORT_TYPE_COM, 0x18, 0x20, COM_FREQ * 8 },
711 { PUC_PORT_TYPE_COM, 0x18, 0x28, COM_FREQ * 8 },
712 { PUC_PORT_TYPE_COM, 0x18, 0x30, COM_FREQ * 8 },
713 { PUC_PORT_TYPE_COM, 0x18, 0x38, COM_FREQ * 8 },
717 * VScom PCI-800H. Uses 8 16950 UART, behind a PCI chips that offers
718 * 4 com port on PCI device 0 and 4 on PCI device 1. PCI device 0 has
719 * device ID 3 and PCI device 1 device ID 4.
723 { 0x14d2, 0xa003, 0, 0 },
724 { 0xffff, 0xffff, 0, 0 },
726 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 },
727 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 },
728 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 },
729 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 },
734 { 0x14d2, 0xa004, 0, 0 },
735 { 0xffff, 0xffff, 0, 0 },
737 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 },
738 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 },
739 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 },
740 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 },
745 { 0x14d2, 0xa005, 0, 0 },
746 { 0xffff, 0xffff, 0, 0 },
748 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 },
749 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 },
753 /* NEC PK-UG-X001 K56flex PCI Modem card.
754 NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. */
755 { "NEC PK-UG-X001 K56flex PCI Modem",
757 { 0x1033, 0x0074, 0x1033, 0x8014 },
758 { 0xffff, 0xffff, 0xffff, 0xffff },
760 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
767 { 0x1033, 0x007d, 0x1033, 0x8012 },
768 { 0xffff, 0xffff, 0xffff, 0xffff },
770 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ},
774 /* Lava Computers 2SP-PCI */
775 { "Lava Computers 2SP-PCI parallel port",
777 { 0x1407, 0x8000, 0, 0 },
778 { 0xffff, 0xffff, 0, 0 },
780 { PUC_PORT_TYPE_LPT, 0x10, 0x00, 0x00 },
784 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
785 { "Lava Computers dual serial port",
787 { 0x1407, 0x0100, 0, 0 },
788 { 0xffff, 0xfffc, 0, 0 },
790 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
791 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
795 /* Lava Computers newer Quattro-PCI serial ports */
796 { "Lava Computers Quattro-PCI serial port",
798 { 0x1407, 0x0120, 0, 0 },
799 { 0xffff, 0xfffc, 0, 0 },
801 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
802 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
806 /* Lava Computers DSerial PCI serial ports */
807 { "Lava Computers serial port",
809 { 0x1407, 0x0110, 0, 0 },
810 { 0xffff, 0xfffc, 0, 0 },
812 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
816 /* Lava Computers Octopus-550 serial ports */
817 { "Lava Computers Octopus-550 8-port serial",
819 { 0x1407, 0x0180, 0, 0 },
820 { 0xffff, 0xfffc, 0, 0 },
822 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
823 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
824 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
825 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
829 /* US Robotics (3Com) PCI Modems */
830 { "US Robotics (3Com) 3CP5609 PCI 16550 Modem",
832 { 0x12b9, 0x1008, 0, 0 },
833 { 0xffff, 0xffff, 0, 0 },
835 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
839 /* Actiontec 56K PCI Master */
840 { "Actiontec 56K PCI Master",
842 { 0x11c1, 0x0480, 0x0, 0x0 },
843 { 0xffff, 0xffff, 0x0, 0x0 },
845 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
850 * Boards with an Oxford Semiconductor chip.
852 * Oxford Semiconductor provides documentation for their chip at:
853 * <URL:http://www.oxsemi.com/products/uarts/index.html>
855 * As sold by Kouwell <URL:http://www.kouwell.com/>.
856 * I/O Flex PCI I/O Card Model-223 with 4 serial and 1 parallel ports.
859 /* Oxford Semiconductor OX16PCI954 PCI UARTs */
860 { "Qxford Semiconductor OX16PCI954 UARTs",
862 { 0x1415, 0x9501, 0, 0 },
863 { 0xffff, 0xffff, 0, 0 },
865 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
866 { PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ },
867 { PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ },
868 { PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ },
872 /* Oxford Semiconductor OX16PCI954 PCI Parallel port */
873 { "Qxford Semiconductor OX16PCI954 Parallel port",
875 { 0x1415, 0x9513, 0, 0 },
876 { 0xffff, 0xffff, 0, 0 },
878 { PUC_PORT_TYPE_LPT, 0x10, 0x00, 0x00 },
882 /* NetMos 2S1P PCI 16C650 : 2S, 1P */
883 { "NetMos NM9835 Dual UART and 1284 Printer port",
885 { 0x9710, 0x9835, 0, 0 },
886 { 0xffff, 0xffff, 0, 0 },
888 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
889 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
890 { PUC_PORT_TYPE_LPT, 0x18, 0x00, 0x00 },
895 * This is the Middle Digital, Inc. PCI-Weasel, which
896 * uses a PCI interface implemented in FPGA.
898 { "Middle Digital, Inc. Weasel serial port",
900 { 0xdeaf, 0x9051, 0, 0 },
901 { 0xffff, 0xffff, 0, 0 },
903 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
907 /* SD-LAB PCI I/O Card 4S2P */
908 { "Syba Tech Ltd. PCI-4S2P-550-ECP",
910 { 0x1592, 0x0781, 0, 0 },
911 { 0xffff, 0xffff, 0, 0 },
913 { PUC_PORT_TYPE_COM, 0x10, 0x2e8, COM_FREQ },
914 { PUC_PORT_TYPE_COM, 0x10, 0x2f8, COM_FREQ },
915 { PUC_PORT_TYPE_LPT, 0x10, 0x000, 0x00 },
916 { PUC_PORT_TYPE_COM, 0x10, 0x3e8, COM_FREQ },
917 { PUC_PORT_TYPE_COM, 0x10, 0x3f8, COM_FREQ },
918 { PUC_PORT_TYPE_LPT, 0x10, 0x000, 0x00 },
922 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */
923 { "Moxa Technologies, Industio CP-114",
925 { 0x1393, 0x1141, 0, 0 },
926 { 0xffff, 0xffff, 0, 0, },
928 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 },
929 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 },
930 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 },
931 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 },
935 /* Moxa Technologies Co., Ltd. PCI I/O Card 8S RS232 */
936 { "Moxa Technologies, C168H/PCI",
938 { 0x1393, 0x1680, 0, 0 },
939 { 0xffff, 0xffff, 0, 0, },
941 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ * 8 },
942 { PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ * 8 },
943 { PUC_PORT_TYPE_COM, 0x18, 0x10, COM_FREQ * 8 },
944 { PUC_PORT_TYPE_COM, 0x18, 0x18, COM_FREQ * 8 },
945 { PUC_PORT_TYPE_COM, 0x18, 0x20, COM_FREQ * 8 },
946 { PUC_PORT_TYPE_COM, 0x18, 0x28, COM_FREQ * 8 },
947 { PUC_PORT_TYPE_COM, 0x18, 0x30, COM_FREQ * 8 },
948 { PUC_PORT_TYPE_COM, 0x18, 0x38, COM_FREQ * 8 },
952 { "Avlab Technology, PCI IO 2S",
954 { 0x14db, 0x2130, 0, 0 },
955 { 0xffff, 0xffff, 0, 0 },
957 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
958 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
962 /* Avlab Technology, Inc. Low Profile PCI 4 Serial: 4S */
963 { "Avlab Low Profile PCI 4 Serial",
965 { 0x14db, 0x2150, 0, 0 },
966 { 0xffff, 0xffff, 0, 0 },
968 { PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
969 { PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
970 { PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
971 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
975 /* Decision Computer Inc, serial ports */
976 { "Decision Computer Inc, PCCOM 4-port serial",
978 { 0x6666, 0x0001, 0, 0 },
979 { 0xffff, 0xffff, 0, 0 },
981 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
982 { PUC_PORT_TYPE_COM, 0x1c, 0x08, COM_FREQ },
983 { PUC_PORT_TYPE_COM, 0x1c, 0x10, COM_FREQ },
984 { PUC_PORT_TYPE_COM, 0x1c, 0x18, COM_FREQ },
988 { "PCCOM dual port RS232/422/485",
990 { 0x6666, 0x0004, 0, 0 },
991 { 0xffff, 0xffff, 0, 0 },
993 { PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
994 { PUC_PORT_TYPE_COM, 0x1c, 0x08, COM_FREQ },