xref: /openbsd-src/sys/dev/pci/pucdata.c (revision 3a3fbb3f2e2521ab7c4a56b7ff7462ebd9095ec5)
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