xref: /openbsd-src/sys/dev/pci/pucdata.c (revision b2ea75c1b17e1a9a339660e7ed45cd24946b230e)
1 /*	$OpenBSD: pucdata.c,v 1.14 2001/08/11 09:47:12 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 	 * Titan PCI-800H. Uses 8 16950 UART, behind a PCI chips that offers
537 	 * 4 com port on PCI device 0 and 4 on PCI device 1. PCI device 0 has
538 	 * device ID 3 and PCI device 1 device ID 4. Uses a 14.7456 Mhz crystal
539 	 * instead of the standart 1.8432Mhz.
540 	 */
541 	{   /* "VScom PCI-800H", */
542 	    {	PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800H_0,	0, 0	},
543 	    {	0xffff, 0xffff,						0, 0	},
544 	    {
545 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 },
546 		{ PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 },
547 		{ PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 },
548 		{ PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 },
549 	    },
550 	},
551 	{   /* "VScom PCI-800H", */
552 	    {	PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI800H_1,	0, 0	},
553 	    {	0xffff, 0xffff,						0, 0	},
554 	    {
555 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ * 8 },
556 		{ PUC_PORT_TYPE_COM, 0x10, 0x08, COM_FREQ * 8 },
557 		{ PUC_PORT_TYPE_COM, 0x10, 0x10, COM_FREQ * 8 },
558 		{ PUC_PORT_TYPE_COM, 0x10, 0x18, COM_FREQ * 8 },
559 	    },
560 	},
561 
562 	/*
563 	 * VScom PCI-200L has 2 x 16550 UARTS.
564 	 * The board has a jumper which allows you to select a clock speed
565 	 * of either 14.7456MHz or 1.8432MHz. By default it runs at the
566 	 * latter.  If pins 2 & 3 are shorted, use COM_FREQ * 8 instead.
567 	 */
568 	{   /* "VScom PCI-200L with 2 x 16550 UARTS" */
569 	    {	PCI_VENDOR_OXFORD, PCI_PRODUCT_OXFORD_VSCOM_PCI200L,	0, 0	},
570 	    {	0xffff, 0xffff,					    	0, 0	},
571 	    {
572 		{ PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
573 		{ PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
574 	    },
575 	},
576 
577 	/* NEC PK-UG-X001 K56flex PCI Modem card.
578 	   NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. */
579 	{   /* "NEC PK-UG-X001 K56flex PCI Modem", */
580 	    {	PCI_VENDOR_NEC,	PCI_PRODUCT_NEC_MARTH,	0x1033,	0x8014	},
581 	    {	0xffff,	0xffff,				0xffff,	0xffff	},
582 	    {
583 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
584 	    },
585 	},
586 
587 	/*NEC PK-UG-X008 */
588 	{   /* "NEC PK-UG-X008", */
589 	    {	PCI_VENDOR_NEC,	PCI_PRODUCT_NEC_PKUG,	0x1033,	0x8012	},
590 	    {	0xffff,	0xffff,				0xffff,	0xffff	},
591 	    {
592 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
593 	    },
594 	},
595 
596 	/* Lava Computers 2SP-PCI (0x8000-0x8003) */
597 	{   /* "Lava Computers 2SP-PCI parallel port", */
598 	    {	PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_1P,	0,	0	},
599 	    {	0xffff,	0xfffc,					0,	0	},
600 	    {
601 		{ PUC_PORT_TYPE_LPT, 0x10, 0x00 },
602 	    },
603 	},
604 
605 	/* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
606 	{   /* "Lava Computers dual serial port", */
607 	    {	PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_2S,	0,	0	},
608 	    {	0xffff,	0xfffc,				0,	0	},
609 	    {
610 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
611 		{ PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
612 	    },
613 	},
614 
615 	/* Lava Computers LavaPort-Dual and LavaPort-Quad 4*clock PCI serial ports */
616 	{   /* "Lava Computers high-speed port", */
617 	    {	PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_LAVAPORT_0,	0,	0	},
618 	    {	0xffff,	0xfffc,				0,	0	},
619 	    {
620 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 },
621 		{ PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ*4 },
622 	    },
623 	},
624 
625 	/* Lava Computers LavaPort-650 */
626 	{   /* "Lava Computers high-speed port", */
627 	    {	PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_650,	0,	0	},
628 	    {	0xffff,	0xfffc,				0,	0	},
629 	    {
630 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ*4 },
631 	    },
632 	},
633 
634 	/* Koutech IOFLEX-2S PCI Dual Port Serial, port 1 */
635 	{   /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 1", */
636 	    {	PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_0,	0,	0	},
637 	    {	0xffff,	0xfffc,				0,	0	},
638 	    {
639 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
640 	    },
641 	},
642 
643 	/* Koutech IOFLEX-2S PCI Dual Port Serial, port 2 */
644 	{   /* "Koutech IOFLEX-2S PCI Dual Port Serial, port 2", */
645 	    {	PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_1,	0,	0	},
646 	    {	0xffff,	0xfffc,				0,	0	},
647 	    {
648 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
649 	    },
650 	},
651 
652 	/* Lava Computers Octopus-550 serial ports */
653 	{   /* "Lava Computers Octopus-550 8-port serial", */
654 	    {   PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_OCTOPUS950_0, 0,      0       },
655 	    {   0xffff, 0xfffc,				 0,      0       },
656 	    {
657 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
658 		{ PUC_PORT_TYPE_COM, 0x14, 0x00, COM_FREQ },
659 		{ PUC_PORT_TYPE_COM, 0x18, 0x00, COM_FREQ },
660 		{ PUC_PORT_TYPE_COM, 0x1c, 0x00, COM_FREQ },
661 	    },
662 	},
663 
664 	/* US Robotics (3Com) PCI Modems */
665 	{   /* "US Robotics (3Com) 3CP5609 PCI 16550 Modem", */
666 	    {	PCI_VENDOR_USR, PCI_PRODUCT_USR_3CP5610,	0,	0	},
667 	    {	0xffff,	0xffff,					0,	0	},
668 	    {
669 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
670 	    },
671 	},
672 
673 	/* IBM 33L4618: AT&T/Lucent Venus Modem */
674 	{   /* "IBM 33L4618: AT&T/Lucent Venus Modem", */
675 	    /* "Actiontec 56K PCI Master" */
676 	    {	PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_VENUSMODEM, 0,	0	},
677 	    {	0xffff,	0xffff,					0,	0	},
678 	    {
679 		{ PUC_PORT_TYPE_COM, 0x18, 0x08, COM_FREQ },
680 	    },
681 	},
682 
683 	/* Topic/SmartLink 5634PCV SurfRider */
684 	{   /* "Topic/SmartLink 5634PCV SurfRider", */
685 	    /* "Topic/SmartLink 5634PCV SurfRider" */
686 	    {	PCI_VENDOR_TOPIC, PCI_PRODUCT_TOPIC_5634PCV,	0,	0	},
687 	    {	0xffff,	0xffff,					0,	0	},
688 	    {
689 		{ PUC_PORT_TYPE_COM, 0x10, 0x00, COM_FREQ },
690 	    },
691 	},
692 
693 	{   /* NULL, */
694 
695 	    {	0,	0,	0,	0	},
696 	    {	0,	0,	0,	0	},
697 	    {
698 		{ 0, 0, 0 },
699 	    },
700 	}
701 };
702