xref: /netbsd-src/sys/dev/pci/pucdata.c (revision 819c8bfd8a175f7a0b229c04fa9b10212bdbdde0)
1 /*	$NetBSD: pucdata.c,v 1.118 2024/12/12 14:23:52 msaitoh Exp $	*/
2 
3 /*
4  * Copyright (c) 1998, 1999 Christopher G. Demetriou.  All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
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
20  *
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.
31  */
32 
33 /*
34  * PCI "universal" communications card driver configuration data (used to
35  * match/attach the cards).
36  */
37 
38 #include <sys/cdefs.h>
39 __KERNEL_RCSID(0, "$NetBSD: pucdata.c,v 1.118 2024/12/12 14:23:52 msaitoh Exp $");
40 
41 #include <sys/param.h>
42 #include <sys/systm.h>
43 #include <sys/device.h>
44 
45 #include <dev/pci/pcidevs.h>
46 #include <dev/pci/pcireg.h>
47 #include <dev/pci/pcivar.h>
48 #include <dev/pci/pucvar.h>
49 #include <dev/ic/comreg.h>
50 
51 const struct puc_device_description puc_devices[] = {
52 	/*
53 	 * Advantech multi serial cards
54 	 */
55 	/* Advantech PCI-1604UP 2 UARTs based on OX16PCI952 */
56 	{   "Advantech PCI-1604UP UARTs",
57 	    {	PCI_VENDOR_ADVANTECH,	PCI_PRODUCT_ADVANTECH_PCI1604, 0, 0 },
58 	    {	0xffff,	0xffff,	0x0,	0x0 },
59 	    {
60 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
61 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
62 	    },
63 	},
64 
65 	{   "Advantech PCI-1610 UARTs",
66 	    {	PCI_VENDOR_ADVANTECH,	PCI_PRODUCT_ADVANTECH_PCI1600,
67 		PCI_PRODUCT_ADVANTECH_PCI1610,	0x0 },
68 	    {	0xffff,	0xffff,	0xffff,	0x0 },
69 	    {
70 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
71 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
72 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
73 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
74 	    },
75 	},
76 
77 	{   "Advantech PCI-1612 UARTs",
78 	    {	PCI_VENDOR_ADVANTECH,	PCI_PRODUCT_ADVANTECH_PCI1600,
79 		PCI_PRODUCT_ADVANTECH_PCI1612,	0x0 },
80 	    {	0xffff,	0xffff,	0xffff,	0x0 },
81 	    {
82 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
83 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
84 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
85 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
86 	    },
87 	},
88 
89 	/* The use of subvendor ID is bit strange... */
90 	{   "Advantech PCI-1620 (1-4) UARTs",
91 	    {	PCI_VENDOR_ADVANTECH,	PCI_PRODUCT_ADVANTECH_PCI1600,
92 		PCI_PRODUCT_ADVANTECH_PCI1620,	0x0 },
93 	    {	0xffff,	0xffff,	0xffff,	0x0 },
94 	    {
95 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
96 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
97 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
98 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
99 	    },
100 	},
101 
102 	/* The use of subvendor ID is bit strange... */
103 	{   "Advantech PCI-1620 (5-8) UARTs",
104 	    {	PCI_VENDOR_ADVANTECH,	PCI_PRODUCT_ADVANTECH_PCI1620_1,
105 		PCI_PRODUCT_ADVANTECH_PCI1620,	0x0 },
106 	    {	0xffff,	0xffff,	0xffff,	0x0 },
107 	    {
108 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 2 },
109 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 2 },
110 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 2 },
111 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 2 },
112 	    },
113 	},
114 
115 	/*
116 	 * Addi-Data APCI-7800 8-port serial card.
117 	 * Uses an AMCC chip as PCI bridge.
118 	 */
119 	{   "Addi-Data APCI-7800",
120 	    {   PCI_VENDOR_AMCIRCUITS, PCI_PRODUCT_AMCIRCUITS_ADDI7800, 0, 0  },
121 	    {   0xffff, 0xffff, 0, 0  },
122 	    {
123 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
124 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ },
125 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
126 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ },
127 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
128 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ },
129 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
130 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
131 	    },
132 	},
133 
134 	/*
135 	 * Amazon.com EC2 virtual 16650-compatible PCI serial device.
136 	 */
137 	{   "Amazon.com EC2 Serial",
138 	    {	PCI_VENDOR_AMAZON, PCI_PRODUCT_AMAZON_UART,	0, 0  },
139 	    {	0xffff, 0xffff,					0, 0  },
140 	    {
141 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
142 	    }
143 	},
144 
145 	/* ASIX PCIe AX99100 : 4S */
146 	{   "ASIX AX99100 UART",
147 	    {	PCI_VENDOR_ASIX, PCI_PRODUCT_ASIX_AX99100,	0xa000, 0x1000 },
148 	    {	0xffff, 0xffff,					0xffff, 0xffff },
149 	    {
150 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
151 	    },
152 	},
153 
154 	/* Avlab Technology, Inc. PCI 2 Serial: 2S */
155 	{   "Avlab PCI 2 Serial",
156 	    {	PCI_VENDOR_AVLAB, PCI_PRODUCT_AVLAB_PCI2S,	0, 0  },
157 	    {	0xffff,	0xffff,					0, 0  },
158 	    {
159 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
160 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
161 	    },
162 	},
163 
164 	/* Avlab Technology, Inc. Low Profile PCI 4 Serial: 4S */
165 	{   "Avlab Low Profile PCI 4 Serial",
166 	    {	PCI_VENDOR_AVLAB, PCI_PRODUCT_AVLAB_LPPCI4S,	0, 0 },
167 	    {	0xffff,	0xffff,	0,	0	},
168 	    {
169 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
170 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
171 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
172 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
173 	    },
174 	},
175 
176 	/* Avlab Technology, Inc. Low Profile PCI 4 Serial: 4S */
177 	{   "Avlab Low Profile PCI 4 Serial",
178 	    {	PCI_VENDOR_AVLAB, PCI_PRODUCT_AVLAB_LPPCI4S_2,	0, 0  },
179 	    {	0xffff,	0xffff,					0, 0  },
180 	    {
181 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
182 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
183 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
184 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
185 	    },
186 	},
187 
188 	/*
189 	 * B&B Electronics MIPort Serial cards.
190 	 */
191 	{   "BBELEC ISOLATED_2_PORT",
192 	    {	PCI_VENDOR_BBELEC, PCI_PRODUCT_BBELEC_ISOLATED_2_PORT, 0, 0 },
193 	    {	0xffff, 0xffff, 0,	0	},
194 	    {
195 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
196 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
197 	    },
198 	},
199 	{   "BBELEC ISOLATED_4_PORT",
200 	    {	PCI_VENDOR_BBELEC, PCI_PRODUCT_BBELEC_ISOLATED_4_PORT, 0, 0 },
201 	    {	0xffff, 0xffff, 0,	0	},
202 	    {
203 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
204 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
205 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
206 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
207 	    },
208 	},
209 	{   "BBELEC ISOLATED_8_PORT",
210 	    {	PCI_VENDOR_BBELEC, PCI_PRODUCT_BBELEC_ISOLATED_8_PORT, 0, 0 },
211 	    {	0xffff, 0xffff, 0,	0	},
212 	    {
213 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
214 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
215 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
216 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
217 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
218 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
219 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
220 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
221 	    },
222 	},
223 
224 	/*
225 	 * Brainboxes Ltd
226 	 */
227 	{ "Brainboxes IS-100",
228 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IS100, 0, 0 },
229 	    { 0xffff, 0xffff, 0, 0 },
230 	    {
231 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
232 	    },
233 	},
234 	{ "Brainboxes IS-200",
235 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IS200, 0, 0 },
236 	    { 0xffff, 0xffff, 0, 0 },
237 	    {
238 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
239 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
240 	    },
241 	},
242 	{ "Brainboxes IS-300",
243 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IS300, 0, 0 },
244 	    { 0xffff, 0xffff, 0, 0 },
245 	    {
246 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
247 	    },
248 	},
249 	{ "Brainboxes IS-400",
250 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IS400, 0, 0 },
251 	    { 0xffff, 0xffff, 0, 0 },
252 	    {
253 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
254 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
255 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
256 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
257 	    },
258 	},
259 	{ "Brainboxes IX-100",
260 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IX100, 0, 0 },
261 	    { 0xffff, 0xffff, 0, 0 },
262 	    {
263 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
264 	    },
265 	},
266 	{ "Brainboxes IX-200",
267 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IX200, 0, 0 },
268 	    { 0xffff, 0xffff, 0, 0 },
269 	    {
270 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
271 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
272 	    },
273 	},
274 	{ "Brainboxes IX-400",
275 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_IX400, 0, 0 },
276 	    { 0xffff, 0xffff, 0, 0 },
277 	    {
278 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
279 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
280 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
281 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
282 	    },
283 	},
284 	{ "Brainboxes UC-101",
285 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC101, 0, 0 },
286 	    { 0xffff, 0xffff, 0, 0 },
287 	    {
288 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
289 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
290 	    },
291 	},
292 	{ "Brainboxes UC-203",
293 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC203, 0, 0 },
294 	    { 0xffff, 0xffff, 0, 0 },
295 	    {
296 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
297 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
298 	    },
299 	},
300 	{ "Brainboxes UC-203",
301 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC203R3, 0, 0 },
302 	    { 0xffff, 0xffff, 0, 0 },
303 	    {
304 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
305 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
306 	    },
307 	},
308 	{ "Brainboxes UC-246",
309 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC246, 0, 0 },
310 	    { 0xffff, 0xffff, 0, 0 },
311 	    {
312 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
313 	    },
314 	},
315 	{ "Brainboxes UC-246",
316 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC246R3, 0, 0 },
317 	    { 0xffff, 0xffff, 0, 0 },
318 	    {
319 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
320 	    },
321 	},
322 	{ "Brainboxes UC-253",
323 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC253, 0, 0 },
324 	    { 0xffff, 0xffff, 0, 0 },
325 	    {
326 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
327 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
328 	    },
329 	},
330 	{ "Brainboxes UC-257",
331 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC257, 0, 0 },
332 	    { 0xffff, 0xffff, 0, 0 },
333 	    {
334 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
335 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
336 	    },
337 	},
338 	{ "Brainboxes UC-257",
339 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC257R3, 0, 0 },
340 	    { 0xffff, 0xffff, 0, 0 },
341 	    {
342 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
343 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
344 	    },
345 	},
346 	{ "Brainboxes UC-257",
347 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC257R4, 0, 0 },
348 	    { 0xffff, 0xffff, 0, 0 },
349 	    {
350 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
351 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
352 	    },
353 	},
354 	{ "Brainboxes UC-260",
355 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC260, 0, 0 },
356 	    { 0xffff, 0xffff, 0, 0 },
357 	    {
358 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
359 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
360 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
361 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
362 	    },
363 	},
364 	{ "Brainboxes UC-268",
365 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC268, 0, 0 },
366 	    { 0xffff, 0xffff, 0, 0 },
367 	    {
368 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
369 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
370 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
371 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
372 	    },
373 	},
374 	{ "Brainboxes UC-279",
375 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC279, 0, 0 },
376 	    { 0xffff, 0xffff, 0, 0 },
377 	    {
378 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
379 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
380 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
381 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
382 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0020, COM_FREQ },
383 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0028, COM_FREQ },
384 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0030, COM_FREQ },
385 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0038, COM_FREQ },
386 	    },
387 	},
388 	{ "Brainboxes UC-302",
389 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC302, 0, 0 },
390 	    { 0xffff, 0xffff, 0, 0 },
391 	    {
392 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
393 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
394 	    },
395 	},
396 	{ "Brainboxes UC-302",
397 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC302R3, 0, 0 },
398 	    { 0xffff, 0xffff, 0, 0 },
399 	    {
400 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
401 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
402 	    },
403 	},
404 	{ "Brainboxes UC-302",
405 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC302R4, 0, 0 },
406 	    { 0xffff, 0xffff, 0, 0 },
407 	    {
408 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
409 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
410 	    },
411 	},
412 	{ "Brainboxes UC-310",
413 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC310, 0, 0 },
414 	    { 0xffff, 0xffff, 0, 0 },
415 	    {
416 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
417 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
418 	    },
419 	},
420 	{ "Brainboxes UC-313",
421 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC313, 0, 0 },
422 	    { 0xffff, 0xffff, 0, 0 },
423 	    {
424 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
425 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
426 	    },
427 	},
428 	{ "Brainboxes UC-313",
429 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC313R3, 0, 0 },
430 	    { 0xffff, 0xffff, 0, 0 },
431 	    {
432 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
433 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
434 	    },
435 	},
436 	{ "Brainboxes UC-313",
437 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC313R4, 0, 0 },
438 	    { 0xffff, 0xffff, 0, 0 },
439 	    {
440 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
441 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
442 	    },
443 	},
444 	{ "Brainboxes UC-324",
445 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC324, 0, 0 },
446 	    { 0xffff, 0xffff, 0, 0 },
447 	    {
448 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
449 	    },
450 	},
451 	{ "Brainboxes UC-346",
452 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC346, 0, 0 },
453 	    { 0xffff, 0xffff, 0, 0 },
454 	    {
455 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
456 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
457 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
458 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
459 	    },
460 	},
461 	{ "Brainboxes UC-346",
462 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC346R3, 0, 0 },
463 	    { 0xffff, 0xffff, 0, 0 },
464 	    {
465 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
466 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
467 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
468 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
469 	    },
470 	},
471 	{ "Brainboxes UC-357",
472 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC357, 0, 0 },
473 	    { 0xffff, 0xffff, 0, 0 },
474 	    {
475 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
476 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
477 	    },
478 	},
479 	{ "Brainboxes UC-357",
480 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC357R3, 0, 0 },
481 	    { 0xffff, 0xffff, 0, 0 },
482 	    {
483 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
484 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
485 	    },
486 	},
487 	{ "Brainboxes UC-357",
488 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC357R4, 0, 0 },
489 	    { 0xffff, 0xffff, 0, 0 },
490 	    {
491 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
492 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
493 	    },
494 	},
495 	{ "Brainboxes UC-368",
496 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC368, 0, 0 },
497 	    { 0xffff, 0xffff, 0, 0 },
498 	    {
499 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
500 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
501 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
502 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
503 	    },
504 	},
505 	{ "Brainboxes UC-414",
506 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC414, 0, 0 },
507 	    { 0xffff, 0xffff, 0, 0 },
508 	    {
509 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
510 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
511 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
512 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
513 	    },
514 	},
515 	{ "Brainboxes UC-420",
516 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC420, 0, 0 },
517 	    { 0xffff, 0xffff, 0, 0 },
518 	    {
519 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
520 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
521 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
522 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
523 	    },
524 	},
525 	{ "Brainboxes UC-431",
526 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC431, 0, 0 },
527 	    { 0xffff, 0xffff, 0, 0 },
528 	    {
529 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
530 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
531 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
532 	    },
533 	},
534 	{ "Brainboxes UC-475",
535 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC475, 0, 0 },
536 	    { 0xffff, 0xffff, 0, 0 },
537 	    {
538 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
539 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
540 	    },
541 	},
542 	{ "Brainboxes UC-475",
543 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC475R3, 0, 0 },
544 	    { 0xffff, 0xffff, 0, 0 },
545 	    {
546 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
547 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
548 	    },
549 	},
550 	{ "Brainboxes UC-607",
551 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC607, 0, 0 },
552 	    { 0xffff, 0xffff, 0, 0 },
553 	    {
554 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
555 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
556 	    },
557 	},
558 	{ "Brainboxes UC-607",
559 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC607R3, 0, 0 },
560 	    { 0xffff, 0xffff, 0, 0 },
561 	    {
562 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
563 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
564 	    },
565 	},
566 	{ "Brainboxes UC-607",
567 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC607R4, 0, 0 },
568 	    { 0xffff, 0xffff, 0, 0 },
569 	    {
570 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
571 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
572 	    },
573 	},
574 	{ "Brainboxes UC-836",
575 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UC836, 0, 0 },
576 	    { 0xffff, 0xffff, 0, 0 },
577 	    {
578 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
579 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
580 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
581 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
582 	    },
583 	},
584 	{ "Brainboxes UP-189",
585 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP189, 0, 0 },
586 	    { 0xffff, 0xffff, 0, 0 },
587 	    {
588 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
589 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
590 	    },
591 	},
592 	{ "Brainboxes UP-189",
593 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP189R3, 0, 0 },
594 	    { 0xffff, 0xffff, 0, 0 },
595 	    {
596 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
597 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
598 	    },
599 	},
600 	{ "Brainboxes UP-189",
601 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP189R4, 0, 0 },
602 	    { 0xffff, 0xffff, 0, 0 },
603 	    {
604 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
605 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
606 	    },
607 	},
608 	{ "Brainboxes UP-200",
609 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP200, 0, 0 },
610 	    { 0xffff, 0xffff, 0, 0 },
611 	    {
612 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
613 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
614 	    },
615 	},
616 	{ "Brainboxes UP-200",
617 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP200R3, 0, 0 },
618 	    { 0xffff, 0xffff, 0, 0 },
619 	    {
620 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
621 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
622 	    },
623 	},
624 	{ "Brainboxes UP-200",
625 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP200R4, 0, 0 },
626 	    { 0xffff, 0xffff, 0, 0 },
627 	    {
628 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
629 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
630 	    },
631 	},
632 	{ "Brainboxes UP-869",
633 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP869, 0, 0 },
634 	    { 0xffff, 0xffff, 0, 0 },
635 	    {
636 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
637 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
638 	    },
639 	},
640 	{ "Brainboxes UP-869",
641 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP869R3, 0, 0 },
642 	    { 0xffff, 0xffff, 0, 0 },
643 	    {
644 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
645 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
646 	    },
647 	},
648 	{ "Brainboxes UP-869",
649 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP869R4, 0, 0 },
650 	    { 0xffff, 0xffff, 0, 0 },
651 	    {
652 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
653 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
654 	    },
655 	},
656 	{ "Brainboxes UP-880",
657 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP880, 0, 0 },
658 	    { 0xffff, 0xffff, 0, 0 },
659 	    {
660 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
661 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
662 	    },
663 	},
664 	{ "Brainboxes UP-880",
665 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP880R3, 0, 0 },
666 	    { 0xffff, 0xffff, 0, 0 },
667 	    {
668 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
669 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
670 	    },
671 	},
672 	{ "Brainboxes UP-880",
673 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_UP880R4, 0, 0 },
674 	    { 0xffff, 0xffff, 0, 0 },
675 	    {
676 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
677 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
678 	    },
679 	},
680 	{ "Brainboxes PX-101",
681 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX101, 0, 0 },
682 	    { 0xffff, 0xffff, 0, 0 },
683 	    {
684 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
685 	    },
686 	},
687 	{ "Brainboxes PX-101",
688 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX101R3, 0, 0 },
689 	    { 0xffff, 0xffff, 0, 0 },
690 	    {
691 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
692 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
693 	    },
694 	},
695 	{ "Brainboxes PX-246",
696 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX246, 0, 0 },
697 	    { 0xffff, 0xffff, 0, 0 },
698 	    {
699 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
700 	    },
701 	},
702 	{ "Brainboxes PX-246",
703 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX246R3, 0, 0 },
704 	    { 0xffff, 0xffff, 0, 0 },
705 	    {
706 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
707 	    },
708 	},
709 	{ "Brainboxes PX-257",
710 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX257, 0, 0 },
711 	    { 0xffff, 0xffff, 0, 0 },
712 	    {
713 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
714 	    },
715 	},
716 	{ "Brainboxes PX-257",
717 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX257R3, 0, 0 },
718 	    { 0xffff, 0xffff, 0, 0 },
719 	    {
720 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
721 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
722 	    },
723 	},
724 	{ "Brainboxes PX-260",
725 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX260, 0, 0 },
726 	    { 0xffff, 0xffff, 0, 0 },
727 	    {
728 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
729 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
730 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
731 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
732 	    },
733 	},
734 	{ "Brainboxes PX-279",
735 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX279, 0, 0 },
736 	    { 0xffff, 0xffff, 0, 0 },
737 	    {
738 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0000, COM_FREQ },
739 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0008, COM_FREQ },
740 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0010, COM_FREQ },
741 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0018, COM_FREQ },
742 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0020, COM_FREQ },
743 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0028, COM_FREQ },
744 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0030, COM_FREQ },
745 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x0038, COM_FREQ },
746 	    },
747 	},
748 	{ "Brainboxes PX-310",
749 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX310, 0, 0 },
750 	    { 0xffff, 0xffff, 0, 0 },
751 	    {
752 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
753 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
754 	    },
755 	},
756 	{ "Brainboxes PX-313",
757 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX313, 0, 0 },
758 	    { 0xffff, 0xffff, 0, 0 },
759 	    {
760 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
761 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
762 	    },
763 	},
764 	{ "Brainboxes PX-320",
765 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX320, 0, 0 },
766 	    { 0xffff, 0xffff, 0, 0 },
767 	    {
768 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
769 	    },
770 	},
771 	{ "Brainboxes PX-346",
772 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX346, 0, 0 },
773 	    { 0xffff, 0xffff, 0, 0 },
774 	    {
775 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
776 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
777 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
778 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
779 	    },
780 	},
781 	{ "Brainboxes PX-368",
782 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX368, 0, 0 },
783 	    { 0xffff, 0xffff, 0, 0 },
784 	    {
785 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
786 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
787 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
788 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
789 	    },
790 	},
791 	{ "Brainboxes PX-420",
792 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX420, 0, 0 },
793 	    { 0xffff, 0xffff, 0, 0 },
794 	    {
795 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
796 	    },
797 	},
798 	{ "Brainboxes PX-420",
799 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX420R3, 0, 0 },
800 	    { 0xffff, 0xffff, 0, 0 },
801 	    {
802 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
803 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
804 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
805 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
806 	    },
807 	},
808 	{ "Brainboxes PX-431",
809 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX431, 0, 0 },
810 	    { 0xffff, 0xffff, 0, 0 },
811 	    {
812 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
813 	    },
814 	},
815 	{ "Brainboxes PX-431",
816 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX431R3, 0, 0 },
817 	    { 0xffff, 0xffff, 0, 0 },
818 	    {
819 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
820 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
821 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
822 	    },
823 	},
824 	{ "Brainboxes PX-475",
825 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX475, 0, 0 },
826 	    { 0xffff, 0xffff, 0, 0 },
827 	    {
828 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
829 	    },
830 	},
831 	{ "Brainboxes PX-803",
832 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX803, 0, 0 },
833 	    { 0xffff, 0xffff, 0, 0 },
834 	    {
835 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
836 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
837 	    },
838 	},
839 	{ "Brainboxes PX-820",
840 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX820, 0, 0 },
841 	    { 0xffff, 0xffff, 0, 0 },
842 	    {
843 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
844 	    },
845 	},
846 	{ "Brainboxes PX-820",
847 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX820R3, 0, 0 },
848 	    { 0xffff, 0xffff, 0, 0 },
849 	    {
850 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
851 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
852 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
853 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
854 	    },
855 	},
856 	{ "Brainboxes PX-831",
857 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX831, 0, 0 },
858 	    { 0xffff, 0xffff, 0, 0 },
859 	    {
860 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
861 	    },
862 	},
863 	{ "Brainboxes PX-831",
864 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX831R3, 0, 0 },
865 	    { 0xffff, 0xffff, 0, 0 },
866 	    {
867 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
868 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
869 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
870 	    },
871 	},
872 	{ "Brainboxes PX-846",
873 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX846, 0, 0 },
874 	    { 0xffff, 0xffff, 0, 0 },
875 	    {
876 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
877 	    },
878 	},
879 	{ "Brainboxes PX-846",
880 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX846R3, 0, 0 },
881 	    { 0xffff, 0xffff, 0, 0 },
882 	    {
883 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
884 	    },
885 	},
886 	{ "Brainboxes PX-857",
887 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX857, 0, 0 },
888 	    { 0xffff, 0xffff, 0, 0 },
889 	    {
890 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ },
891 	    },
892 	},
893 	{ "Brainboxes PX-857",
894 	    { PCI_VENDOR_BRAINBOXES, PCI_PRODUCT_BRAINBOXES_PX857R3, 0, 0 },
895 	    { 0xffff, 0xffff, 0, 0 },
896 	    {
897 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
898 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
899 	    },
900 	},
901 
902 	/*
903 	 * Comtrol
904 	 */
905 	{   "Comtrol RocketPort 550/8 RJ11 part A",
906 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT550811A,
907 		0, 0 },
908 	    {	0xffff,	0xffff,	0,	0 },
909 	    {
910 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
911 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
912 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
913 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
914 	    },
915 	},
916 	{   "Comtrol RocketPort 550/8 RJ11 part B",
917 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT550811B,
918 		0, 0 },
919 	    {	0xffff,	0xffff,	0,	0 },
920 	    {
921 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
922 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
923 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
924 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
925 	    },
926 	},
927 	{   "Comtrol RocketPort 550/8 Octa part A",
928 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508OA,
929 		0, 0 },
930 	    {	0xffff,	0xffff,	0,	0 },
931 	    {
932 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
933 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
934 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
935 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
936 	    },
937 	},
938 	{   "Comtrol RocketPort 550/8 Octa part B",
939 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508OB,
940 		0, 0 },
941 	    {	0xffff,	0xffff,	0,	0 },
942 	    {
943 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
944 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
945 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
946 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
947 	    },
948 	},
949 	{   "Comtrol RocketPort 550/4 RJ45",
950 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5504, 0, 0 },
951 	    {	0xffff,	0xffff,	0,	0 },
952 	    {
953 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
954 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
955 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
956 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
957 	    },
958 	},
959 	{   "Comtrol RocketPort 550/Quad",
960 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT550Q, 0, 0 },
961 	    {	0xffff,	0xffff,	0,	0 },
962 	    {
963 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
964 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
965 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
966 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
967 	    },
968 	},
969 	{   "Comtrol RocketPort 550/16 part A",
970 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT55016A,
971 		0, 0 },
972 	    {	0xffff,	0xffff,	0,	0 },
973 	    {
974 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
975 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
976 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
977 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
978 	    },
979 	},
980 	{   "Comtrol RocketPort 550/16 part B",
981 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT55016B,
982 		0, 0 },
983 	    {	0xffff,	0xffff,	0,	0 },
984 	    {
985 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
986 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
987 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
988 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
989 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ * 4},
990 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ * 4},
991 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ * 4},
992 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ * 4},
993 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x40, COM_FREQ * 4},
994 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x48, COM_FREQ * 4},
995 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x50, COM_FREQ * 4},
996 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x58, COM_FREQ * 4},
997 	    },
998 	},
999 	{   "Comtrol RocketPort 550/8 part A",
1000 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508A,
1001 		0, 0 },
1002 	    {	0xffff,	0xffff,	0,	0 },
1003 	    {
1004 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
1005 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
1006 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
1007 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
1008 	    },
1009 	},
1010 	{   "Comtrol RocketPort 550/8 part B",
1011 	    {	PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508B,
1012 		0, 0 },
1013 	    {	0xffff,	0xffff,	0,	0 },
1014 	    {
1015 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
1016 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
1017 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
1018 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
1019 	    },
1020 	},
1021 
1022 	/*
1023 	 * Decision PCCOM PCI series. PLX 9052 with 1 or 2 16554 UARTS
1024 	 */
1025 	/* Decision Computer Inc PCCOM 2 Port RS232/422/485: 2S */
1026 	{   "Decision Computer Inc PCCOM 2 Port RS232/422/485",
1027 	    {	PCI_VENDOR_DCI,	PCI_PRODUCT_DCI_APCI2,	0x0,	0x0	},
1028 	    {	0xffff,	0xffff,	0x0,	0x0	},
1029 	    {
1030 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
1031 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ},
1032 	    },
1033 	},
1034 
1035 	/* Decision Computer Inc PCCOM 4 Port RS232/422/485: 4S */
1036 	{   "Decision Computer Inc PCCOM 4 Port RS232/422/485",
1037 	    {	PCI_VENDOR_DCI,	PCI_PRODUCT_DCI_APCI4,	0x0,	0x0	},
1038 	    {	0xffff,	0xffff,	0x0,	0x0	},
1039 	    {
1040 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
1041 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ},
1042 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x10, COM_FREQ},
1043 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x18, COM_FREQ},
1044 	    },
1045 	},
1046 
1047 	/* Decision Computer Inc PCCOM 8 Port RS232/422/485: 8S */
1048 	{   "Decision Computer Inc PCCOM 8 Port RS232/422/485",
1049 	    {	PCI_VENDOR_DCI,	PCI_PRODUCT_DCI_APCI8,	0x0,	0x0	},
1050 	    {	0xffff,	0xffff,	0x0,	0x0	},
1051 	    {
1052 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
1053 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ},
1054 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x10, COM_FREQ},
1055 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x18, COM_FREQ},
1056 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x20, COM_FREQ},
1057 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x28, COM_FREQ},
1058 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x30, COM_FREQ},
1059 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x38, COM_FREQ},
1060 	    },
1061 	},
1062 
1063 	/* Digi International Digi Neo 4 Serial */
1064 	{   "Digi International Digi Neo 4 Serial",
1065 	    {	PCI_VENDOR_DIGI, PCI_PRODUCT_DIGI_NEO4,		0, 0  },
1066 	    {	0xffff, 0xffff,					0, 0  },
1067 	    {
1068 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1069 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1070 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
1071 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
1072 	    },
1073 	},
1074 
1075 	/* Digi International Digi Neo 8 Serial */
1076 	{   "Digi International Digi Neo 8 Serial",
1077 	    {	PCI_VENDOR_DIGI, PCI_PRODUCT_DIGI_NEO8,		0, 0  },
1078 	    {	0xffff, 0xffff,					0, 0  },
1079 	    {
1080 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1081 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1082 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
1083 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
1084 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
1085 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
1086 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
1087 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
1088 	    },
1089 	},
1090 
1091 	/* Digi International Digi Neo 8 Serial (PCIe) */
1092 	{   "Digi International Digi Neo 8 Serial (PCIe)",
1093 	    {	PCI_VENDOR_DIGI, PCI_PRODUCT_DIGI_NEO8_PCIE,	0, 0  },
1094 	    {	0xffff, 0xffff,					0, 0  },
1095 	    {
1096 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1097 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1098 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
1099 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
1100 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
1101 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
1102 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
1103 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
1104 	    },
1105 	},
1106 
1107 	{   "EXAR XR17D152",
1108 	    {   PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D152, 0,      0       },
1109 	    {   0xffff, 0xffff, 0,      0       },
1110 	    {
1111 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1112 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1113 	    },
1114 	},
1115 	{   "EXAR XR17D154",
1116 	    {   PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D154, 0,      0       },
1117 	    {   0xffff, 0xffff, 0,      0       },
1118 	    {
1119 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1120 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1121 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
1122 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
1123 	    },
1124 	},
1125 	{   "EXAR XR17D154",
1126 	    {	PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17V354, 0,      0       },
1127 	    {   0xffff, 0xffff, 0,      0       },
1128 	    {
1129 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, 125000000 },
1130 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, 125000000 },
1131 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, 125000000 },
1132 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, 125000000 },
1133 	    },
1134 	},
1135 
1136 	/*
1137 	 * Multi-Tech ISI5634PCI/4 4-port modem board.
1138 	 * Has a 4-channel Exar XR17C154 UART, but with bogus product ID in its
1139 	 * config EEPROM.
1140 	 */
1141 	{   "Multi-Tech ISI5634PCI/4",
1142 	    {   PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D158, 0x2205,      0x2003       },
1143 	    {   0xffff, 0xffff, 0xffff,      0xffff       },
1144 	    {
1145 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1146 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1147 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
1148 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
1149 	    },
1150 	},
1151 
1152 	{   "EXAR XR17D158",
1153 	    {   PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D158, 0,      0       },
1154 	    {   0xffff, 0xffff, 0,      0       },
1155 	    {
1156 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
1157 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
1158 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
1159 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
1160 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
1161 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
1162 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
1163 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
1164 	    },
1165 	},
1166 
1167 	/* IBM SurePOS 300 Series (481033H) serial ports */
1168 	{   "IBM SurePOS 300 Series (481033H)",
1169 	    {   PCI_VENDOR_IBM, PCI_PRODUCT_IBM_4810_SCC, 0, 0 },
1170 	    {   0xffff, 0xffff,                           0, 0 },
1171 	    {
1172 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ }, /* Port C */
1173 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ }, /* Port D */
1174 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ }, /* Port E */
1175 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ }, /* Port F */
1176 	    },
1177 	},
1178 
1179 	/* I-O DATA RSA-PCI: 2S */
1180 	{   "I-O DATA RSA-PCI 2-port serial",
1181 	    {	PCI_VENDOR_IODATA, PCI_PRODUCT_IODATA_RSAPCI, 0, 0 },
1182 	    {	0xffff, 0xffff, 0, 0 },
1183 	    {
1184 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1185 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1186 	    },
1187 	},
1188 
1189 	/* Lava Computers 2SP-PCI */
1190 	{   "Lava Computers 2SP-PCI parallel port",
1191 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_TWOSP_1P, 0, 0 },
1192 	    {	0xffff,	0xffff,	0,	0	},
1193 	    {
1194 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1195 	    },
1196 	},
1197 
1198 	/* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
1199 	{   "Lava Computers dual serial port",
1200 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_TWOSP_2S, 0, 0 },
1201 	    {	0xffff,	0xfffc,	0,	0	},
1202 	    {
1203 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1204 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1205 	    },
1206 	},
1207 
1208 	/* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
1209 	{   "Lava Computers Quattro A",
1210 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_QUATTRO_AB, 0, 0 },
1211 	    {	0xffff,	0xfffc,	0,	0	},
1212 	    {
1213 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1214 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1215 	    },
1216 	},
1217 
1218 	/* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
1219 	{   "Lava Computers Quattro B",
1220 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_QUATTRO_CD, 0, 0 },
1221 	    {	0xffff,	0xfffc,	0,	0	},
1222 	    {
1223 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1224 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1225 	    },
1226 	},
1227 
1228 	/* Lava Computers DSerial PCI serial ports */
1229 	{   "Lava Computers serial port",
1230 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_IOFLEX_2S_0, 0, 0 },
1231 	    {	0xffff,	0xfffc,	0,	0	},
1232 	    {
1233 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1234 	    },
1235 	},
1236 
1237 	/* Lava Computers Quattro-PCI serial ports */
1238 	{   "Lava Quattro-PCI A 4-port serial",
1239 	    {   PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_AB2, 0, 0 },
1240 	    {   0xffff, 0xfffc, 0,	0	},
1241 	    {
1242 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1243 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1244 	    },
1245 	},
1246 
1247 	/* Lava Computers Quattro-PCI serial ports */
1248 	{   "Lava Quattro-PCI B 4-port serial",
1249 	    {   PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_CD2, 0, 0 },
1250 	    {   0xffff, 0xfffc, 0,	0	},
1251 	    {
1252 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1253 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1254 	    },
1255 	},
1256 
1257 	/* Lava Computers Octopus-550 serial ports */
1258 	{   "Lava Computers Octopus-550 8-port serial",
1259 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_OCTOPUS550_0, 0, 0 },
1260 	    {	0xffff,	0xfffc,	0,	0	},
1261 	    {
1262 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1263 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1264 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1265 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1266 	    },
1267 	},
1268 
1269 	/* Lava Computers Octopus-550 serial ports */
1270 	{   "Lava Computers Octopus-550 B 8-port serial",
1271 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_OCTOPUS550_1, 0, 0 },
1272 	    {	0xffff,	0xfffc,	0,	0	},
1273 	    {
1274 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1275 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1276 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1277 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1278 	    },
1279 	},
1280 
1281 	/* Lava Computers single port serial PCI card */
1282 	{   "Lava Computers SSERIAL-PCI",
1283 	    {	PCI_VENDOR_LAVA,	PCI_PRODUCT_LAVA_SSERIAL, 0, 0 },
1284 	    {	0xffff,	0xffff,	0,	0	},
1285 	    {
1286 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1287 	    },
1288 	},
1289 
1290 	/* Actiontec  56K PCI Master */
1291 	{   "Actiontec 56K PCI Master",
1292 	    {	PCI_VENDOR_LUCENT,	PCI_PRODUCT_LUCENT_VENUSMODEM,
1293 		0x0, 0x0 },
1294 	    {	0xffff,	0xffff,	0x0,	0x0	},
1295 	    {
1296 		{ PUC_PORT_TYPE_COM, PCI_BAR1,	0x00, COM_FREQ },
1297 	    },
1298 	},
1299 
1300 	/*
1301 	 * This is the Middle Digital, Inc. PCI-Weasel, which
1302 	 * uses a PCI interface implemented in FPGA.
1303 	 */
1304 	{   "Middle Digital, Inc. Weasel serial port",
1305 	    {	PCI_VENDOR_MIDDLE_DIGITAL,
1306 		PCI_PRODUCT_MIDDLE_DIGITAL_WEASEL_SERIAL, 0, 0 },
1307 	    {	0xffff,	0xffff,	0,	0	},
1308 	    {
1309 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1310 	    },
1311 	},
1312 
1313 	/* Moxa Technologies Co., Ltd. PCI I/O Card 2S RS232 */
1314 	{   "Moxa Technologies, SmartIO CP-102/PCI",
1315 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_CP102U, 0, 0 },
1316 	    {	0xffff,	0xffff,	0,	0	},
1317 	    {
1318 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1319 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1320 	    },
1321 	},
1322 
1323 	/* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */
1324 	{   "Moxa Technologies, SmartIO C104H/PCI",
1325 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_C104H, 0, 0 },
1326 	    {	0xffff,	0xffff,	0,	0	},
1327 	    {
1328 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1329 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1330 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1331 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1332 	    },
1333 	},
1334 
1335 	/* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232 */
1336 	{   "Moxa Technologies, SmartIO CP-104/PCI",
1337 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_CP104, 0, 0 },
1338 	    {	0xffff,	0xffff,	0,	0	},
1339 	    {
1340 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1341 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1342 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1343 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1344 	    },
1345 	},
1346 
1347 	/* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232 */
1348 	{   "Moxa Technologies, SmartIO CP-104-V2/PCI",
1349 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_CP104V2, 0, 0 },
1350 	    {	0xffff,	0xffff,	0,	0	},
1351 	    {
1352 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1353 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1354 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1355 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1356 	    },
1357 	},
1358 
1359 	/* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232 */
1360 	{   "Moxa Technologies, SmartIO CP-104-EL/PCIe",
1361 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_CP104EL, 0, 0 },
1362 	    {	0xffff,	0xffff,	0,	0	},
1363 	    {
1364 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1365 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1366 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1367 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1368 	    },
1369 	},
1370 
1371 	/* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */
1372 	{   "Moxa Technologies, SmartIO CP-114/PCI",
1373 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_CP114, 0, 0 },
1374 	    {	0xffff,	0xffff,	0,	0	},
1375 	    {
1376 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1377 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1378 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1379 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1380 	    },
1381 	},
1382 
1383 	/* Moxa Technologies Co., Ltd. PCI I/O Card 8S RS232 */
1384 	{   "Moxa Technologies, SmartIO C168H/PCI",
1385 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_C168H, 0, 0 },
1386 	    {	0xffff,	0xffff,	0,	0	},
1387 	    {
1388 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1389 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1390 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1391 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1392 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
1393 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
1394 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
1395 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
1396 	    },
1397 	},
1398 
1399 	/* Moxa Technologies Co., Ltd. PCI I/O Card 8S RS232 */
1400 	{   "Moxa Technologies, SmartIO C168U/PCI",
1401 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_C168U, 0, 0 },
1402 	    {	0xffff,	0xffff,	0,	0	},
1403 	    {
1404 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1405 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1406 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1407 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1408 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
1409 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
1410 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
1411 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
1412 	    },
1413 	},
1414 
1415 	/* Moxa Technologies Co., Ltd. PCI-Express I/O Card 8S RS232 */
1416 	{   "Moxa Technologies, SmartIO C168EL/PCIe",
1417 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_C168EL, 0, 0 },
1418 	    {	0xffff,	0xffff,	0,	0	},
1419 	    {
1420 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
1421 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
1422 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
1423 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
1424 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
1425 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
1426 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
1427 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
1428 	    },
1429 	},
1430 	/* Moxa Technologies Co., Ltd. PCI-Express I/O Card 8S RS232 */
1431 	{   "Moxa Technologies, SmartIO CP-168EL-A/PCIe",
1432 	    {	PCI_VENDOR_MOXA,	PCI_PRODUCT_MOXA_C168ELA, 0, 0 },
1433 	    {	0xffff,	0xffff,	0,	0	},
1434 	    {
1435 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x000, COM_FREQ * 8 },
1436 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x200, COM_FREQ * 8 },
1437 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x400, COM_FREQ * 8 },
1438 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x600, COM_FREQ * 8 },
1439 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x800, COM_FREQ * 8 },
1440 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0xa00, COM_FREQ * 8 },
1441 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0xc00, COM_FREQ * 8 },
1442 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0xe00, COM_FREQ * 8 },
1443 	    },
1444 	},
1445 
1446 	/* NEC PK-UG-X001 K56flex PCI Modem card.
1447 	   NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. */
1448 	{   "NEC PK-UG-X001 K56flex PCI Modem",
1449 	    {	PCI_VENDOR_NEC,	PCI_PRODUCT_NEC_PKUGX001, PCI_VENDOR_NEC,
1450 		0x8014 },
1451 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1452 	    {
1453 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1454 	    },
1455 	},
1456 
1457 	/* NEC PK-UG-X008 */
1458 	{   "NEC PK-UG-X008",
1459 	    {	PCI_VENDOR_NEC,	PCI_PRODUCT_NEC_PKUGX008, PCI_VENDOR_NEC,
1460 		0x8012 },
1461 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1462 	    {
1463 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ},
1464 	    },
1465 	},
1466 
1467 	/* NetMos 1P PCI : 1P */
1468 	{   "NetMos NM9805 1284 Printer port",
1469 	    {	PCI_VENDOR_NETMOS,	PCI_PRODUCT_NETMOS_NM9805, 0, 0	},
1470 	    {	0xffff,	0xffff,	0,	0	},
1471 	    {
1472 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1473 	    },
1474 	},
1475 
1476 	/* NetMos 2P PCI : 2P */
1477 	{   "NetMos NM9815 Dual 1284 Printer port",
1478 	    {	PCI_VENDOR_NETMOS,	PCI_PRODUCT_NETMOS_NM9815, 0, 0	},
1479 	    {	0xffff,	0xffff,	0,	0	},
1480 	    {
1481 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1482 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
1483 	    },
1484 	},
1485 
1486 	/* NetMos 1S PCI NM9835 : 1S */
1487 	{   "NetMos NM9835 UART",
1488 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9835, 0x1000, 0x0001 },
1489 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
1490 	    {
1491 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1492 	    },
1493 	},
1494 
1495 	/* NetMos 2S PCI NM9835 : 2S */
1496 	{   "NetMos NM9835 Dual UART",
1497 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9835, 0x1000, 0x0002 },
1498 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
1499 	    {
1500 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1501 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1502 	    },
1503 	},
1504 
1505 	/* NetMos 2S1P PCI 16C650 : 2S, 1P */
1506 	{   "NetMos NM9835 Dual UART and 1284 Printer port",
1507 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9835, 0, 0 },
1508 	    {	0xffff,	0xffff,	0,	0	},
1509 	    {
1510 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1511 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1512 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
1513 	    },
1514 	},
1515 
1516 	/* NetMos 4S0P PCI NM9845 : 4S, 0P */
1517 	{   "NetMos NM9845 Quad UART",
1518 	   {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0x1000, 0x0004 },
1519 	   {   0xffff, 0xffff, 0xffff, 0xffff  },
1520 	   {
1521 	       { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1522 	       { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1523 	       { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1524 	       { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1525 	   },
1526 	},
1527 
1528 	/* NetMos 4S1P PCI NM9845 : 4S, 1P */
1529 	{   "NetMos NM9845 Quad UART and 1284 Printer port",
1530 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0x1000, 0x0014 },
1531 	    {   0xffff, 0xffff, 0xffff, 0xffff  },
1532 	    {
1533 	       { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1534 	       { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1535 	       { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1536 	       { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1537 	       { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
1538 	    },
1539 	},
1540 
1541 	/* NetMos 6S PCI 16C650 : 6S, 0P */
1542 	{   "NetMos NM9845 6 UART",
1543 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0x1000, 0x0006 },
1544 	    {   0xffff, 0xffff, 0xffff, 0xffff  },
1545 	    {
1546 	       { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1547 	       { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1548 	       { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1549 	       { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1550 	       { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
1551 	       { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ },
1552 	    },
1553 	},
1554 
1555 	/* NetMos 4S1P PCI NM9845 : 4S, 1P */
1556 	{   "NetMos NM9845 Quad UART and 1284 Printer port (unknown type)",
1557 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0, 0 },
1558 	    {	0xffff,	0xffff,	0,	0	},
1559 	    {
1560 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1561 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1562 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1563 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1564 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
1565 	    },
1566 	},
1567 
1568 	/* NetMos 4S1P PCI NM9855 : 4S, 1P */
1569 	{   "NetMos NM9855 Quad UART and 1284 Printer port (unknown type)",
1570 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9855, 0x1000, 0x0014 },
1571 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1572 	    {
1573 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1574 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1575 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1576 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
1577 		{ PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ },
1578 	    },
1579 	},
1580 
1581 	/* NetMos 6S PCI NM9865 : 1S */
1582 	{   "NetMos NM9865 1 UART",
1583 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x1000 },
1584 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1585 	    {
1586 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1587 	    },
1588 	},
1589 
1590 	/* NetMos PCI NM9865 : 1P */
1591 	{   "NetMos NM9865 Single LPT",
1592 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x2000 },
1593 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1594 	    {
1595 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1596 	    },
1597 	},
1598 
1599 	/* NetMos 2S PCI NM9865 : 2S */
1600 	{   "NetMos NM9865 2 UART",
1601 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3002 },
1602 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1603 	    {
1604 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1605 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1606 	    },
1607 	},
1608 
1609 	/* NetMos 3S PCI NM9865 : 3S */
1610 	{   "NetMos NM9865 3 UART",
1611 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3003 },
1612 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1613 	    {
1614 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1615 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1616 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1617 	    },
1618 	},
1619 
1620 	/* NetMos 4S PCI NM9865 : 4S */
1621 	{   "NetMos NM9865 4 UART",
1622 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3004 },
1623 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1624 	    {
1625 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1626 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1627 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1628 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1629 	    },
1630 	},
1631 
1632 	/* NetMos PCI NM9865 : 1S 1P */
1633 	{   "NetMos NM9865 Single UART and Single LPT",
1634 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3011 },
1635 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1636 	    {
1637 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1638 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1639 	    },
1640 	},
1641 
1642 	/* NetMos PCI NM9865 : 2S 1P */
1643 	{   "NetMos NM9865 Dual UART and Single LPT",
1644 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3012 },
1645 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1646 	    {
1647 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1648 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1649 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
1650 	    },
1651 	},
1652 
1653 	/* NetMos PCI NM9865 : 2P */
1654 	{   "NetMos NM9865 Dual LPT",
1655 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3020 },
1656 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1657 	    {
1658 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1659 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1660 	    },
1661 	},
1662 
1663 	/*
1664 	 * Two 1-port and one 2-port found on a 4-port
1665 	 * card sold as Sunsway/ST Lab I-430.
1666 	 */
1667 	{   "NetMos NM9865 1S",
1668 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x1000 },
1669 	    {	0xffff, 0xffff, 0xffff, 0xffff },
1670 	    {
1671 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1672 	    },
1673 	},
1674 	{   "NetMos NM9865 2S",
1675 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3002 },
1676 	    {	0xffff, 0xffff, 0xffff, 0xffff },
1677 	    {
1678 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1679 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1680 	    },
1681 	},
1682 
1683 	/* NetMos PCIe NM9900 : 4S */
1684 	{   "NetMos NM9900 UART",
1685 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9900, 0xa000, 0x1000 },
1686 	    {	0xffff,	0xffff,				      0xffff, 0xffff },
1687 	    {
1688 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1689 	    },
1690 	},
1691 
1692 	/* NetMos PCIe NM9900 : 8S */
1693 	{   "NetMos NM9900 UART 8S",
1694 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9900, 0xa000, 0x3002 },
1695 	    {	0xffff,	0xffff,				      0xffff, 0xffff },
1696 	    {
1697 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1698 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1699 	    },
1700 	},
1701 
1702 	/* NetMos PCIe Peripheral Controller :UART part */
1703 	{   "NetMos NM9901 UART",
1704 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9901, 0xa000, 0x1000 },
1705 	    {	0xffff,	0xffff,				      0xffff, 0xffff },
1706 	    {
1707 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1708 	    },
1709 	},
1710 
1711 	/* NetMos PCIe NM9901 : 1P */
1712 	{   "NetMos NM9901 LPT",
1713 	    {	PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9901, 0xa000, 0x2000 },
1714 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1715 	    {
1716 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1717 	    },
1718 	},
1719 
1720 	/* NetMos PCIe NM9904 (PCI multi function): 4S */
1721 	{   "NetMos NM9904 UART",
1722 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9904, 0, 0 },
1723 	    {	0xffff,	0xffff,				      0, 0 },
1724 	    {
1725 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1726 	    },
1727 	},
1728 
1729 	/* NetMos PCIe NM9912 */
1730 	{ "NetMos NM9912 Dual PCI-E UART and 1284 Printer Port",
1731 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9912, 0, 0x1000 },
1732 	    {   0xffff, 0xffff, 0, 0xffff },
1733 	    {
1734 		{ PUC_PORT_TYPE_COM, 0x10, 0x0000, 0 },
1735 	    },
1736 	},
1737 
1738 	{ "NetMos NM9912 Dual PCI-E UART and 1284 Printer Port",
1739 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9912, 0, 0x2000 },
1740 	    {   0xffff, 0xffff, 0, 0xffff },
1741 	    {
1742 		{ PUC_PORT_TYPE_LPT, 0x10, 0x0000, 0 },
1743 	    },
1744 	},
1745 
1746 	/* NetMos PCIe NM9922 (PCI multi function): 2S */
1747 	{   "NetMos NM9922 UART",
1748 	    {   PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9922, 0, 0 },
1749 	    {	0xffff,	0xffff,				      0, 0 },
1750 	    {
1751 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1752 	    },
1753 	},
1754 
1755 	/*
1756 	 * Boards with an Oxford Semiconductor chip.
1757 	 *
1758 	 * Oxford Semiconductor provides documentation for their chip at:
1759 	 * <URL:http://www.plxtech.com/products/uart>
1760 	 *
1761 	 * As sold by Kouwell <URL:http://www.kouwell.com/>.
1762 	 * I/O Flex PCI I/O Card Model-223 with 4 serial and 1 parallel ports.
1763 	 */
1764 
1765 	/* Oxford Semiconductor OXPCIe952 PCIe 1P */
1766 	{   "Oxford Semiconductor OXPCIe952 LPT",
1767 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952P,
1768 		0, 0},
1769 	    {	0xffff,	0xffff,	0,	0	},
1770 	    {
1771 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1772 	    },
1773 	},
1774 
1775 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1776 	{   "Oxford Semiconductor OXPCIe952 UART",
1777 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_0,
1778 		0, 0 },
1779 	    {	0xffff,	0xffff,	0,	0	},
1780 	    {
1781 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1782 	    },
1783 	},
1784 
1785 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1786 	{   "Oxford Semiconductor OXPCIe952 UART",
1787 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_1,
1788 		0, 0 },
1789 	    {	0xffff,	0xffff,	0,	0	},
1790 	    {
1791 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1792 	    },
1793 	},
1794 
1795 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1796 	{   "Oxford Semiconductor OXPCIe952 UARTs",
1797 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_2S,
1798 		PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_2S },
1799 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1800 	    {
1801 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1802 	    },
1803 	},
1804 
1805 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1806 	{   "Oxford Semiconductor OXPCIe952 UART",
1807 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_2,
1808 		0, 0 },
1809 	    {	0xffff,	0xffff,	0,	0	},
1810 	    {
1811 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1812 	    },
1813 	},
1814 
1815 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1816 	{   "Oxford Semiconductor OXPCIe952 UART",
1817 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_3,
1818 		0, 0 },
1819 	    {	0xffff,	0xffff,	0,	0	},
1820 	    {
1821 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1822 	    },
1823 	},
1824 
1825 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1826 	{   "Oxford Semiconductor OXPCIe952 UART",
1827 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_4,
1828 		0, 0 },
1829 	    {	0xffff,	0xffff,	0,	0	},
1830 	    {
1831 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1832 	    },
1833 	},
1834 
1835 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1836 	{   "Oxford Semiconductor OXPCIe952 UART",
1837 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_5,
1838 		0, 0 },
1839 	    {	0xffff,	0xffff,	0,	0	},
1840 	    {
1841 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1842 	    },
1843 	},
1844 
1845 	/* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1846 	{   "Oxford Semiconductor OXPCIe952 UART",
1847 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_6,
1848 		0, 0 },
1849 	    {	0xffff,	0xffff,	0,	0	},
1850 	    {
1851 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1852 	    },
1853 	},
1854 
1855 	/* Oxford Semiconductor OXmPCI952 PCI UARTs */
1856 	{   "Oxford Semiconductor OXmPCI952 UARTs",
1857 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41092,
1858 		0, 0 },
1859 	    {	0xffff,	0xffff,	0,	0	},
1860 	    {
1861 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1862 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1863 	    },
1864 	},
1865 
1866 	/* Oxford Semiconductor OXuPCI952 950 PCI UARTs */
1867 	{   "Oxford Semiconductor OXuPCI952 UARTs",
1868 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OXUPCI952,
1869 		0, 0 },
1870 	    {	0xffff, 0xffff, 0,	0	},
1871 	    {
1872 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1873 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
1874 	    },
1875 	},
1876 
1877 	/* Oxford Semiconductor OX16PCI952 PCI `950 UARTs - 128 byte FIFOs */
1878 	{   "Oxford Semiconductor OX16PCI952 UARTs",
1879 	    {   PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI952,
1880 		0, 0 },
1881 	    {   0xffff, 0xffff, 0,	0	},
1882 	    {
1883 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1884 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1885 	    },
1886 	},
1887 
1888 	/* Oxford Semiconductor OX16PCI952 PCI Parallel port */
1889 	{   "Oxford Semiconductor OX16PCI952 Parallel port",
1890 	    {   PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI952P,
1891 		0, 0 },
1892 	    {   0xffff, 0xffff, 0,	0	},
1893 	    {
1894 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1895 	    },
1896 	},
1897 
1898 	/* InnoSys Keyspan SX Pro OX16PCI954 based 4 UARTs */
1899 	{   "InnoSys Keyspan SX Pro Serial Card",
1900 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1901 		PCI_VENDOR_INNOSYS, 0x5850 },
1902 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1903 	    {
1904 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1905 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1906 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
1907 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
1908 	    },
1909 	},
1910 
1911 	/* I-O DATA RSA-PCI2 two UARTs based on OX16PCI954 */
1912 	{   "I-O DATA RSA-PCI2 UARTs",
1913 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1914 		PCI_VENDOR_IODATA, 0xc070 },
1915 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1916 	    {
1917 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1918 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1919 	    },
1920 	},
1921 
1922 	/* I-O DATA RSA-PCI2 four/eight(1-4) UARTs based on OX16PCI954 */
1923 	{   "I-O DATA RSA-PCI2/P4 or P8 (1-4) UARTs",
1924 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1925 		PCI_VENDOR_IODATA, 0xd007 },
1926 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1927 	    {
1928 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1929 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1930 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
1931 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
1932 	    },
1933 	},
1934 
1935 	/* OEM of Oxford Semiconductor PCI UARTs? */
1936 	{   "SIIG Cyber 4 PCI 16550",
1937 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1938 		PCI_VENDOR_SIIG, 0x2050	},
1939 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1940 	    {
1941 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1942 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1943 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10 },
1944 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10 },
1945 	    },
1946 	},
1947 
1948 	/* OEM of Oxford Semiconductor PCI UARTs? */
1949 	{   "SIIG Cyber 4S PCI 16C650 (20x family)",
1950 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1951 		PCI_VENDOR_SIIG, 0x2051	},
1952 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1953 	    {
1954 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1955 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1956 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10 },
1957 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10 },
1958 	    },
1959 	},
1960 
1961 	/* OEM of Oxford Semiconductor PCI UARTs? */
1962 	{   "Avlab LP PCI 4S Quartet",
1963 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1964 		PCI_VENDOR_AVLAB, 0x2150 },
1965 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
1966 	    {
1967 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1968 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1969 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10 },
1970 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10 },
1971 	    },
1972 	},
1973 
1974 	/* Oxford Semiconductor OX16PCI954 PCI UARTs */
1975 	{   "Oxford Semiconductor OX16PCI954 UARTs",
1976 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1977 		PCI_VENDOR_OXFORDSEMI,	0 },
1978 	    {	0xffff,	0xffff,	0xffff,	0	},
1979 	    {
1980 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1981 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1982 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
1983 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
1984 	    },
1985 	},
1986 
1987 	/* Oxford Semiconductor OX16PCI954 PCI UARTs (default for 0x9501) */
1988 	{   "Oxford Semiconductor OX16PCI954 UARTs",
1989 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1990 		0, 0 },
1991 	    {	0xffff,	0xffff,	0,	0	},
1992 	    {
1993 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ},
1994 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ},
1995 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ},
1996 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ},
1997 	    },
1998 	},
1999 
2000 	/* Oxford Semiconductor Exsys EX-41098 PCI UARTs */
2001 	{   "Oxford Semiconductor Exsys EX-41098 UARTs",
2002 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41098,
2003 		PCI_VENDOR_OXFORDSEMI,	0 },
2004 	    {	0xffff,	0xffff,	0xffff,	0	},
2005 	    {
2006 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2007 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2008 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
2009 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
2010 	    },
2011 	},
2012 
2013 	/* I-O DATA RSA-PCI2 eight(5-8) UARTs base on OX16PCI954 */
2014 	{   "I-O DATA RSA-PCI2/P8 (5-8) UARTs",
2015 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41098,
2016 		PCI_VENDOR_IODATA, 0xd007 },
2017 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2018 	    {
2019 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
2020 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
2021 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
2022 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
2023 	    },
2024 	},
2025 
2026 	/* Exsys EX-41098, second part of SIIG Cyber 8S PCI Card */
2027 	{   "Exsys EX-41098",
2028 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41098,
2029 		PCI_VENDOR_SIIG, 0x2082	},
2030 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2031 	    {
2032 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10},
2033 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10},
2034 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10},
2035 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10},
2036 	    },
2037 	},
2038 
2039 	/* Oxford Semiconductor OX16PCI954 PCI Parallel port */
2040 	{   "Oxford Semiconductor OX16PCI954 Parallel port",
2041 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI954P,
2042 		0, 0 },
2043 	    {	0xffff,	0xffff,	0,	0	},
2044 	    {
2045 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
2046 	    },
2047 	},
2048 
2049 	/* EXSYS EX-41098-2 UARTs */
2050 	{   "EXSYS EX-41098-2 UARTs",
2051 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI958,
2052 		PCI_VENDOR_OXFORDSEMI, 0x0671 },
2053 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2054 	    {
2055 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ},
2056 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ},
2057 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ},
2058 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ},
2059 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ},
2060 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ},
2061 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ},
2062 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ},
2063 	    },
2064 	},
2065 
2066 	/* Oxford Semiconductor OX16PCI958 UARTs (wildcard) */
2067 	{   "Oxford Semiconductor OX16PCI958 UARTs",
2068 	    {	PCI_VENDOR_OXFORDSEMI,	PCI_PRODUCT_OXFORDSEMI_OX16PCI958,
2069 		0, 0 },
2070 	    {	0xffff,	0xffff,	0,	0	},
2071 	    {
2072 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 10},
2073 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 10},
2074 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 10},
2075 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 10},
2076 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 10},
2077 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 10},
2078 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 10},
2079 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 10},
2080 	    },
2081 	},
2082 
2083 	/* Oxford Semiconductor OXPCIe952 PCIe 1 native S */
2084 	{   "Oxford Semiconductor OXPCIe952 UART",
2085 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952SN1,
2086 		0, 0 },
2087 	    {	0xffff,	0xffff,	0,	0	},
2088 	    {
2089 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
2090 	    },
2091 	},
2092 
2093 	/* Oxford Semiconductor OXPCIe952 PCIe 2 native S */
2094 	{   "Oxford Semiconductor OXPCIe952 UART",
2095 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952SN2,
2096 		0, 0 },
2097 	    {	0xffff,	0xffff,	0,	0	},
2098 	    {
2099 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
2100 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
2101 	    },
2102 	},
2103 
2104 	/* Oxford Semiconductor OXPCIe952 PCIe 2 native S */
2105 	{   "Oxford Semiconductor OXPCIe952 UART",
2106 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952SN2_2,
2107 		0, 0 },
2108 	    {	0xffff,	0xffff,	0,	0	},
2109 	    {
2110 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
2111 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
2112 	    },
2113 	},
2114 
2115 	/* Oxford Semiconductor OXPCIe954 PCIe 4 native S */
2116 	{   "Oxford Semiconductor OXPCIe954 UART",
2117 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE954,
2118 		0, 0 },
2119 	    {	0xffff,	0xffff,	0,	0	},
2120 	    {
2121 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
2122 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
2123 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
2124 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
2125 	    },
2126 	},
2127 
2128 	/* Oxford Semiconductor OXPCIe954 PCIe 4 native S */
2129 	{   "Oxford Semiconductor OXPCIe954 UART",
2130 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE954SN4,
2131 		0, 0 },
2132 	    {	0xffff,	0xffff,	0,	0	},
2133 	    {
2134 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
2135 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
2136 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
2137 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
2138 	    },
2139 	},
2140 
2141 	/* Oxford Semiconductor OXPCIe958 PCIe 8 native S */
2142 	{   "Oxford Semiconductor OXPCIe958 UART",
2143 	    {	PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE958SN8,
2144 		0, 0 },
2145 	    {	0xffff,	0xffff,	0,	0	},
2146 	    {
2147 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
2148 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
2149 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
2150 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
2151 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1800, COM_FREQ * 0x22 },
2152 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1a00, COM_FREQ * 0x22 },
2153 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1c00, COM_FREQ * 0x22 },
2154 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x1e00, COM_FREQ * 0x22 },
2155 	    },
2156 	},
2157 
2158 	{   "SUNIX 5008 1P",
2159 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2160 		0x1fd4,	0x0100 },
2161 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
2162 	    {
2163 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2164 	    },
2165 	},
2166 
2167 	{   "SUNIX 5016 8S",
2168 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2169 		0x1fd4,	0x0010 },
2170 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2171 	    {
2172 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2173 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2174 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
2175 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
2176 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8},
2177 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ * 8},
2178 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x10, COM_FREQ * 8},
2179 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x18, COM_FREQ * 8},
2180 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x20, COM_FREQ * 8},
2181 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x28, COM_FREQ * 8},
2182 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x30, COM_FREQ * 8},
2183 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x38, COM_FREQ * 8},
2184 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x40, COM_FREQ * 8},
2185 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x48, COM_FREQ * 8},
2186 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x50, COM_FREQ * 8},
2187 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x58, COM_FREQ * 8},
2188 	    },
2189 	},
2190 
2191 	{   "SUNIX 5027 1S",
2192 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2193 		0x1fd4,	0x0001 },
2194 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2195 	    {
2196 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2197 	    },
2198 	},
2199 
2200 	{   "SUNIX 5037 2S",
2201 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2202 		0x1fd4,	0x0002 },
2203 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2204 	    {
2205 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2206 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2207 	    },
2208 	},
2209 
2210 	{   "SUNIX 5056 4S",
2211 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2212 		0x1fd4,	0x0004 },
2213 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2214 	    {
2215 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2216 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2217 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
2218 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
2219 	    },
2220 	},
2221 
2222 	{   "SUNIX 5066 8S",
2223 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2224 		0x1fd4,	0x0008 },
2225 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2226 	    {
2227 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2228 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2229 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
2230 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
2231 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8},
2232 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ * 8},
2233 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x10, COM_FREQ * 8},
2234 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x18, COM_FREQ * 8},
2235 	    },
2236 	},
2237 
2238 	{   "SUNIX 5069 1S / 1P",
2239 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2240 		0x1fd4,	0x0101 },
2241 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
2242 	    {
2243 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2244 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2245 	    },
2246 	},
2247 
2248 	{   "SUNIX 5079 2S / 1P",
2249 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2250 		0x1fd4,	0x0102 },
2251 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2252 	    {
2253 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2254 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2255 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2256 	    },
2257 	},
2258 
2259 	{   "SUNIX 5099 4S / 1P",
2260 	    {	PCI_VENDOR_SUNIX2,	PCI_PRODUCT_SUNIX2_SER5XXXX,
2261 		0x1fd4,	0x0104 },
2262 	    {	0xffff,	0xffff,	0xffff,	0xffff },
2263 	    {
2264 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2265 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2266 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
2267 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
2268 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2269 	    },
2270 	},
2271 
2272 	/*
2273 	 * XXX no entry because I have no data:
2274 	 * XXX Dolphin Peripherals 4006 (single parallel)
2275 	 */
2276 
2277 	/*
2278 	 * Dolphin Peripherals 4014 (dual parallel port) card.  PLX 9050, with
2279 	 * a seemingly-lame EEPROM setup that puts the Dolphin IDs
2280 	 * into the subsystem fields, and claims that it's a
2281 	 * network/misc (0x02/0x80) device.
2282 	 */
2283 	{   "Dolphin Peripherals 4014",
2284 	    {	PCI_VENDOR_PLX,	PCI_PRODUCT_PLX_9050,	0xd84d,	0x6810	},
2285 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2286 	    {
2287 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2288 		{ PUC_PORT_TYPE_LPT, PCI_BAR5, 0x00, 0x00 },
2289 	    },
2290 	},
2291 
2292 	/*
2293 	 * XXX Dolphin Peripherals 4025 (single serial)
2294 	 * (clashes with Dolphin Peripherals  4036 (2s variant)
2295 	 */
2296 
2297 	/*
2298 	 * Dolphin Peripherals 4035 (dual serial port) card.  PLX 9050, with
2299 	 * a seemingly-lame EEPROM setup that puts the Dolphin IDs
2300 	 * into the subsystem fields, and claims that it's a
2301 	 * network/misc (0x02/0x80) device.
2302 	 */
2303 	{   "Dolphin Peripherals 4035",
2304 	    {	PCI_VENDOR_PLX,	PCI_PRODUCT_PLX_9050,	0xd84d,	0x6808	},
2305 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2306 	    {
2307 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2308 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2309 	    },
2310 	},
2311 
2312 	/*
2313 	 * Nanjing QinHeng Electronics
2314 	 * Products based on CH353 chip which can be
2315 	 * configured to provide various combinations
2316 	 * including 2 serial ports and a parallel port
2317 	 * or 4 serial ports (using a CH432 parallel to
2318 	 * 2 serial port converter. Product codes from
2319 	 * documentation (and physical 2 port serial card)
2320 	 */
2321 	{   "Nanjing QinHeng Electronics CH352",
2322 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_2S,
2323 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_2S },
2324 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2325 	    {
2326 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2327 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2328 	    },
2329 	},
2330 
2331 	{   "Nanjing QinHeng Electronics CH352",
2332 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_1S1P,
2333 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_1S1P },
2334 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2335 	    {
2336 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2337 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2338 	    },
2339 	},
2340 
2341 	{   "Nanjing QinHeng Electronics CH353",
2342 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_4S,
2343 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_4S },
2344 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2345 	    {
2346 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2347 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2348 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2349 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2350 	    },
2351 	},
2352 
2353 	{   "Nanjing QinHeng Electronics CH353",
2354 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_2S1P,
2355 		PCI_VENDOR_QINHENG, 0x3253 },
2356 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2357 	    {
2358 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2359 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2360 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2361 	    },
2362 	},
2363 
2364 	{   "Nanjing QinHeng Electronics CH353 (fixed address)",
2365 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_2S1PAR,
2366 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_2S1PAR },
2367 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2368 	    {
2369 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2370 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2371 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2372 	    },
2373 	},
2374 
2375 	{   "Nanjing QinHeng Electronics CH355",
2376 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH355_4S,
2377 		PCI_VENDOR_QINHENG, 0x3473 },
2378 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2379 	    {
2380 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2381 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2382 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2383 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2384 	    },
2385 	},
2386 
2387 	{   "Nanjing QinHeng Electronics CH356",
2388 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_4S1P,
2389 		PCI_VENDOR_QINHENG, 0x3473 },
2390 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2391 	    {
2392 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2393 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2394 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2395 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2396 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2397 	    },
2398 	},
2399 
2400 	{   "Nanjing QinHeng Electronics CH356",
2401 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_6S,
2402 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_6S },
2403 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2404 	    {
2405 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2406 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2407 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2408 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2409 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
2410 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
2411 	    },
2412 	},
2413 
2414 	{   "Nanjing QinHeng Electronics CH356",
2415 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_8S,
2416 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_8S },
2417 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2418 	    {
2419 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2420 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2421 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2422 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2423 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
2424 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
2425 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ },
2426 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ },
2427 	    },
2428 	},
2429 
2430 	{   "Nanjing QinHeng Electronics CH357",
2431 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH357_4S,
2432 		PCI_VENDOR_QINHENG, 0x5053 },
2433 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2434 	    {
2435 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2436 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2437 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2438 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2439 	    },
2440 	},
2441 
2442 	{   "Nanjing QinHeng Electronics CH358",
2443 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_4S1P,
2444 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_4S1P },
2445 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2446 	    {
2447 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2448 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2449 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2450 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2451 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2452 	    },
2453 	},
2454 
2455 	{   "Nanjing QinHeng Electronics CH358",
2456 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_8S,
2457 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_8S },
2458 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2459 	    {
2460 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2461 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2462 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2463 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2464 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
2465 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ },
2466 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ },
2467 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ },
2468 	    },
2469 	},
2470 
2471 	{   "Nanjing QinHeng Electronics CH359",
2472 	    {	PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH359_16S,
2473 		PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH359_16S },
2474 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2475 	    {
2476 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2477 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
2478 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
2479 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
2480 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
2481 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ },
2482 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ },
2483 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ },
2484 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
2485 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ },
2486 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x20, COM_FREQ },
2487 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x30, COM_FREQ },
2488 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
2489 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ },
2490 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x28, COM_FREQ },
2491 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x38, COM_FREQ },
2492 	    },
2493 	},
2494 
2495 	{   "Nanjing QinHeng Electronics CH382",
2496 	    {	PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S,
2497 		PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S },
2498 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2499 	    {
2500 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
2501 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
2502 	    },
2503 	},
2504 
2505 	{   "Nanjing QinHeng Electronics CH382",
2506 	    {	PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S1P,
2507 		PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S1P },
2508 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2509 	    {
2510 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
2511 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
2512 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2513 	    },
2514 	},
2515 
2516 	{   "Nanjing QinHeng Electronics CH384",
2517 	    {	PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S,
2518 		PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S },
2519 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2520 	    {
2521 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
2522 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
2523 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xd0, COM_FREQ },
2524 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xd8, COM_FREQ },
2525 	    },
2526 	},
2527 
2528 	{   "Nanjing QinHeng Electronics CH384",
2529 	    {	PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S1P,
2530 		PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S1P },
2531 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2532 	    {
2533 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
2534 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
2535 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xd0, COM_FREQ },
2536 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xd8, COM_FREQ },
2537 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2538 	    },
2539 	},
2540 
2541 	{   "Nanjing QinHeng Electronics CH384",
2542 	    {	PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_8S,
2543 		PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_8S },
2544 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2545 	    {
2546 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2547 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ },
2548 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ },
2549 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ },
2550 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
2551 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ },
2552 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ },
2553 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ },
2554 	    },
2555 	},
2556 
2557 	{   "Nanjing QinHeng Electronics CH384",
2558 	    {	PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_28S,
2559 		PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_28S },
2560 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2561 	    {
2562 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
2563 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
2564 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xd0, COM_FREQ },
2565 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xd8, COM_FREQ },
2566 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2567 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ },
2568 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ },
2569 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ },
2570 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
2571 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ },
2572 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ },
2573 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ },
2574 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x40, COM_FREQ },
2575 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x50, COM_FREQ },
2576 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x60, COM_FREQ },
2577 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x70, COM_FREQ },
2578 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x48, COM_FREQ },
2579 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x58, COM_FREQ },
2580 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x68, COM_FREQ },
2581 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x78, COM_FREQ },
2582 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x80, COM_FREQ },
2583 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x90, COM_FREQ },
2584 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xa0, COM_FREQ },
2585 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xb0, COM_FREQ },
2586 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x88, COM_FREQ },
2587 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x98, COM_FREQ },
2588 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xa8, COM_FREQ },
2589 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0xb8, COM_FREQ },
2590 	    },
2591 	},
2592 
2593 	/* Intel 82946GZ/GL KT */
2594 	{   "Intel 82946GZ/GL KT",
2595 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82946GZ_KT, 0, 0 },
2596 	    {	0xffff,	0xffff,	0,	0	},
2597 	    {
2598 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2599 	    },
2600 	},
2601 
2602 	/* Intel P965/G965 KT */
2603 	{   "Intel P965/G965 KT",
2604 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82P965_KT, 0, 0 },
2605 	    {	0xffff,	0xffff,	0,	0	},
2606 	    {
2607 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2608 	    },
2609 	},
2610 
2611 	/* Intel PM965/GM965 KT */
2612 	{   "Intel PM965/GM965 KT",
2613 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82965PM_KT, 0, 0 },
2614 	    {	0xffff,	0xffff,	0,	0	},
2615 	    {
2616 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2617 	    },
2618 	},
2619 
2620 	/* Intel GME965/GLE965 KT */
2621 	{   "Intel GME965/GLE965 KT",
2622 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82965GME_KT, 0, 0 },
2623 	    {	0xffff,	0xffff,	0,	0	},
2624 	    {
2625 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2626 	    },
2627 	},
2628 
2629 	/* Intel Q963/Q965 KT */
2630 	{   "Intel Q963/Q965 KT",
2631 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q965_KT, 0, 0 },
2632 	    {	0xffff,	0xffff,	0,	0	},
2633 	    {
2634 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2635 	    },
2636 	},
2637 
2638 	/* Intel G33/G31/P35/P31 KT */
2639 	{   "Intel G33/G31/P35/P31 KT",
2640 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82G33_KT, 0, 0 },
2641 	    {	0xffff,	0xffff,	0,	0	},
2642 	    {
2643 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2644 	    },
2645 	},
2646 
2647 	/* Intel Q35 KT */
2648 	{   "Intel Q35 KT",
2649 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q35_KT, 0, 0 },
2650 	    {	0xffff,	0xffff,	0,	0	},
2651 	    {
2652 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2653 	    },
2654 	},
2655 
2656 	/* Intel Q33 KT */
2657 	{   "Intel Q33 KT",
2658 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q33_KT, 0, 0 },
2659 	    {	0xffff,	0xffff,	0,	0	},
2660 	    {
2661 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2662 	    },
2663 	},
2664 
2665 	/* Intel X38 KT */
2666 	{   "Intel X38 KT",
2667 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82X38_KT, 0, 0 },
2668 	    {	0xffff,	0xffff,	0,	0	},
2669 	    {
2670 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2671 	    },
2672 	},
2673 
2674 	/* Intel 3200 KT */
2675 	{   "Intel 3200 KT",
2676 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_3200_KT, 0, 0 },
2677 	    {	0xffff,	0xffff,	0,	0	},
2678 	    {
2679 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2680 	    },
2681 	},
2682 
2683 	/* Intel GM45 KT */
2684 	{   "Intel GM45 KT",
2685 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82GM45_KT, 0, 0 },
2686 	    {	0xffff,	0xffff,	0,	0	},
2687 	    {
2688 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2689 	    },
2690 	},
2691 
2692 	/* Intel Q45 KT */
2693 	{   "Intel Q45 KT",
2694 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q45_KT, 0, 0 },
2695 	    {	0xffff,	0xffff,	0,	0	},
2696 	    {
2697 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2698 	    },
2699 	},
2700 
2701 	/* Intel Q45 KT (again) */
2702 	{   "Intel Q45 KT",
2703 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q45_KT_1, 0, 0 },
2704 	    {	0xffff,	0xffff,	0,	0	},
2705 	    {
2706 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2707 	    },
2708 	},
2709 	/* Intel 5 Series and Intel 3400 Series KT */
2710 	{   "Intel 5 Series KT",
2711 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_3400_KT, 0, 0 },
2712 	    {	0xffff,	0xffff,	0,	0	},
2713 	    {
2714 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2715 	    },
2716 	},
2717 
2718 	/* Intel 6 Series KT */
2719 	{   "Intel 6 Series KT",
2720 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_6SERIES_KT, 0, 0 },
2721 	    {	0xffff,	0xffff,	0,	0	},
2722 	    {
2723 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2724 	    },
2725 	},
2726 
2727 	/* Intel 7 Series KT */
2728 	{   "Intel 7 Series KT",
2729 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_7SERIES_KT, 0, 0 },
2730 	    {	0xffff,	0xffff,	0,	0	},
2731 	    {
2732 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2733 	    },
2734 	},
2735 
2736 	/* Intel 8 Series KT */
2737 	{   "Intel 8 Series KT",
2738 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_8SERIES_KT, 0, 0 },
2739 	    {	0xffff,	0xffff,	0,	0	},
2740 	    {
2741 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2742 	    },
2743 	},
2744 
2745 	/* Intel 9 Series KT */
2746 	{   "Intel 9 Series KT",
2747 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_9SERIES_KT, 0, 0 },
2748 	    {	0xffff,	0xffff,	0,	0	},
2749 	    {
2750 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2751 	    },
2752 	},
2753 
2754 	/* Intel 100 Series KT */
2755 	{   "Intel 100 Series KT",
2756 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_100SERIES_KT, 0, 0 },
2757 	    {	0xffff,	0xffff,	0,	0	},
2758 	    {
2759 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2760 	    },
2761 	},
2762 	{   "Intel 100 Series LP KT",
2763 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_100SERIES_LP_KT, 0, 0 },
2764 	    {	0xffff,	0xffff,	0,	0	},
2765 	    {
2766 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2767 	    },
2768 	},
2769 
2770 	/* Intel 200 Series KT */
2771 	{   "Intel 200 Series KT",
2772 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_2HS_KT, 0, 0 },
2773 	    {	0xffff,	0xffff,	0,	0	},
2774 	    {
2775 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2776 	    },
2777 	},
2778 
2779 	/* Intel 300 Series KT */
2780 	{   "Intel 300 Series KT",
2781 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_3HS_KT, 0, 0 },
2782 	    {	0xffff,	0xffff,	0,	0	},
2783 	    {
2784 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2785 	    },
2786 	},
2787 
2788 	/* Intel Comet Lake KT */
2789 	{   "Intel Comet Lake KT",
2790 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_CMTLK_KT, 0, 0 },
2791 	    {	0xffff,	0xffff,	0,	0	},
2792 	    {
2793 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2794 	    },
2795 	},
2796 
2797 	/* Intel 400 Series (H) KT */
2798 	{   "Intel 400 Series (H) KT",
2799 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_4HS_H_KT, 0, 0 },
2800 	    {	0xffff,	0xffff,	0,	0	},
2801 	    {
2802 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2803 	    },
2804 	},
2805 
2806 	/* Intel 400 Series (V) KT */
2807 	{   "Intel 400 Series (V) KT",
2808 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_4HS_V_KT, 0, 0 },
2809 	    {	0xffff,	0xffff,	0,	0	},
2810 	    {
2811 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2812 	    },
2813 	},
2814 
2815 	/* Intel 495 Series KT */
2816 	{   "Intel 495 Series KT",
2817 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_495_YU_KT, 0, 0 },
2818 	    {	0xffff,	0xffff,	0,	0	},
2819 	    {
2820 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2821 	    },
2822 	},
2823 
2824 	/* Intel 500 Series (H) KT */
2825 	{   "Intel 500 Series (H) KT",
2826 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_5HS_H_KT, 0, 0 },
2827 	    {	0xffff,	0xffff,	0,	0	},
2828 	    {
2829 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2830 	    },
2831 	},
2832 
2833 	/* Intel C600/X79 Series KT */
2834 	{   "Intel C600/X79 Series KT",
2835 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_C600_KT, 0, 0 },
2836 	    {	0xffff,	0xffff,	0,	0	},
2837 	    {
2838 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2839 	    },
2840 	},
2841 
2842 	/* Intel Core 4G (mobile) KT */
2843 	{   "Intel Core 4G (mobile) KT",
2844 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_CORE4G_M_KT, 0, 0 },
2845 	    {	0xffff,	0xffff,	0,	0	},
2846 	    {
2847 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2848 	    },
2849 	},
2850 
2851 	/* Intel Core 5G (mobile) KT */
2852 	{   "Intel Core 5G (mobile) KT",
2853 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_CORE5G_M_KT, 0, 0 },
2854 	    {	0xffff,	0xffff,	0,	0	},
2855 	    {
2856 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2857 	    },
2858 	},
2859 
2860 	/* Intel EG20T UART */
2861 	{   "Intel EG20T UART #0",
2862 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_0, 0, 0 },
2863 	    {	0xffff,	0xffff,	0,	0	},
2864 	    {
2865 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2866 	    },
2867 	},
2868 
2869 	/* Intel EG20T UART */
2870 	{   "Intel EG20T UART #1",
2871 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_1, 0, 0 },
2872 	    {	0xffff,	0xffff,	0,	0	},
2873 	    {
2874 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2875 	    },
2876 	},
2877 
2878 	/* Intel EG20T UART */
2879 	{   "Intel EG20T UART #2",
2880 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_2, 0, 0 },
2881 	    {	0xffff,	0xffff,	0,	0	},
2882 	    {
2883 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2884 	    },
2885 	},
2886 
2887 	/* Intel EG20T UART */
2888 	{   "Intel EG20T UART #3",
2889 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_3, 0, 0 },
2890 	    {	0xffff,	0xffff,	0,	0	},
2891 	    {
2892 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2893 	    },
2894 	},
2895 
2896 	/* Intel Quark X1000 UART */
2897 	{   "Intel Quark X1000 UART",
2898 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_X1000_HS_UART, 0, 0 },
2899 	    {	0xffff,	0xffff,	0,	0	},
2900 	    {
2901 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, 44236800 },
2902 	    },
2903 	},
2904 
2905 	/* Intel S1200 UART */
2906 	{   "Intel S1200 UART",
2907 	    {	PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_S1200_UART, 0, 0 },
2908 	    {	0xffff,	0xffff,	0,	0	},
2909 	    {
2910 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2911 	    },
2912 	},
2913 
2914 	/* VScom PCI-200: 2S */
2915 	{   "VScom PCI-200",
2916 	    {	PCI_VENDOR_PLX,	PCI_PRODUCT_PLX_PCI_200,
2917 		PCI_VENDOR_PLX,	0x1103 },
2918 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2919 	    {
2920 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2921 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2922 	    },
2923 	},
2924 
2925 	/* VScom PCI-400: 4S */
2926 	{   "VScom PCI-400",
2927 	    {	PCI_VENDOR_PLX,	PCI_PRODUCT_PLX_PCI_400,
2928 		PCI_VENDOR_PLX,	0x1077	},
2929 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2930 	    {
2931 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2932 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
2933 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
2934 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
2935 	    },
2936 	},
2937 
2938 	/* VScom PCI-800: 8S */
2939 	{   "VScom PCI-800",
2940 	    {	PCI_VENDOR_PLX,	PCI_PRODUCT_PLX_PCI_800,
2941 		PCI_VENDOR_PLX,	0x1076	},
2942 	    {	0xffff,	0xffff,	0xffff,	0xffff	},
2943 	    {
2944 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2945 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
2946 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
2947 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
2948 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
2949 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
2950 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
2951 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
2952 	    },
2953 	},
2954 
2955 	/*
2956 	 * Perle PCI-RAS 4 Modem ports
2957 	 */
2958 	{   "Perle Systems PCI-RAS 4 modem ports",
2959 	    {	PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9030, 0x155f, 0xf001	},
2960 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2961 	    {
2962 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2963 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2964 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2965 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2966 	    },
2967 	},
2968 
2969 	/*
2970 	 * Perle PCI-RASV92 4 Modem ports
2971 	 */
2972 	{   "Perle Systems PCI-RASV92 4 modem ports",
2973 	    {	PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x155f, 0xf001	},
2974 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2975 	    {
2976 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2977 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2978 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2979 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2980 	    },
2981 	},
2982 
2983 	/*
2984 	 * Perle PCI-RAS 8 Modem ports
2985 	 */
2986 	{   "Perle Systems PCI-RAS 8 modem ports",
2987 	    {	PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9030, 0x155f, 0xf010	},
2988 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
2989 	    {
2990 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2991 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2992 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2993 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2994 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 4 },
2995 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 4 },
2996 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 4 },
2997 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 4 },
2998 	    },
2999 	},
3000 
3001 	/*
3002 	 * Perle PCI-RASV92 8 Modem ports
3003 	 */
3004 	{   "Perle Systems PCI-RASV92 8 modem ports",
3005 	    {	PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x155f, 0xf010	},
3006 	    {	0xffff, 0xffff, 0xffff, 0xffff	},
3007 	    {
3008 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
3009 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
3010 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
3011 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
3012 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 4 },
3013 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 4 },
3014 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 4 },
3015 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 4 },
3016 	    },
3017 	},
3018 
3019 	/*
3020 	 * Boca Research Turbo Serial 654 (4 serial port) card.
3021 	 * Appears to be the same as Chase Research PLC PCI-FAST4
3022 	 * and Perle PCI-FAST4 Multi-Port serial cards.
3023 	 */
3024 	{   "Boca Research Turbo Serial 654",
3025 	    {   PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x12e0, 0x0031  },
3026 	    {   0xffff, 0xffff, 0xffff, 0xffff  },
3027 	    {
3028 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
3029 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
3030 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
3031 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
3032 	    },
3033 	},
3034 
3035 	/*
3036 	 * Boca Research Turbo Serial 658 (8 serial port) card.
3037 	 * Appears to be the same as Chase Research PLC PCI-FAST8
3038 	 * and Perle PCI-FAST8 Multi-Port serial cards.
3039 	 */
3040 	{   "Boca Research Turbo Serial 658",
3041 	    {   PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x12e0, 0x0021  },
3042 	    {   0xffff, 0xffff, 0xffff, 0xffff  },
3043 	    {
3044 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
3045 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
3046 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
3047 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
3048 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 4 },
3049 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 4 },
3050 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 4 },
3051 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 4 },
3052 	    },
3053 	},
3054 
3055 	/*
3056 	 * SIIG Boards.
3057 	 *
3058 	 * SIIG provides documentation for their boards at:
3059 	 * <URL:http://www.siig.com/driver.htm>
3060 	 *
3061 	 * Please excuse the weird ordering, it's the order they
3062 	 * use in their documentation.
3063 	 */
3064 
3065 	/*
3066 	 * SIIG "10x" family boards.
3067 	 */
3068 
3069 	/* SIIG Cyber Serial PCI 16C550 (10x family): 1S */
3070 	{   "SIIG Cyber Serial PCI 16C550 (10x family)",
3071 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_S550, 0, 0 },
3072 	    {	0xffff,	0xffff,	0,	0	},
3073 	    {
3074 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3075 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR1 },
3076 	    },
3077 	},
3078 
3079 	/* SIIG Cyber Serial PCI 16C650 (10x family): 1S */
3080 	{   "SIIG Cyber Serial PCI 16C650 (10x family)",
3081 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_S650, 0, 0 },
3082 	    {	0xffff,	0xffff,	0,	0	},
3083 	    {
3084 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3085 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR1 },
3086 	    },
3087 	},
3088 
3089 	/* SIIG Cyber Serial PCI 16C850 (10x family): 1S */
3090 	{   "SIIG Cyber Serial PCI 16C850 (10x family)",
3091 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_S850, 0, 0 },
3092 	    {	0xffff,	0xffff,	0,	0	},
3093 	    {
3094 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3095 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR1 },
3096 	    },
3097 	},
3098 
3099 	/* SIIG Cyber I/O PCI 16C550 (10x family): 1S, 1P */
3100 	{   "SIIG Cyber I/O PCI 16C550 (10x family)",
3101 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_IO550, 0, 0 },
3102 	    {	0xffff,	0xffff,	0,	0	},
3103 	    {
3104 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3105 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
3106 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3107 	    },
3108 	},
3109 
3110 	/* SIIG Cyber I/O PCI 16C650 (10x family): 1S, 1P */
3111 	{   "SIIG Cyber I/O PCI 16C650 (10x family)",
3112 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_IO650, 0, 0 },
3113 	    {	0xffff,	0xffff,	0,	0	},
3114 	    {
3115 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3116 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
3117 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3118 	    },
3119 	},
3120 
3121 	/* SIIG Cyber I/O PCI 16C850 (10x family): 1S, 1P */
3122 	{   "SIIG Cyber I/O PCI 16C850 (10x family)",
3123 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_IO850, 0, 0 },
3124 	    {	0xffff,	0xffff,	0,	0	},
3125 	    {
3126 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3127 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
3128 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3129 	    },
3130 	},
3131 
3132 	/* SIIG Cyber Parallel PCI (10x family): 1P */
3133 	{   "SIIG Cyber Parallel PCI (10x family)",
3134 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_P, 0, 0 },
3135 	    {	0xffff,	0xffff,	0,	0	},
3136 	    {
3137 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3138 	    },
3139 	},
3140 
3141 	/* SIIG Cyber Parallel Dual PCI (10x family): 2P */
3142 	{   "SIIG Cyber Parallel Dual PCI (10x family)",
3143 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2P, 0, 0 },
3144 	    {	0xffff,	0xffff,	0,	0	},
3145 	    {
3146 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3147 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
3148 	    },
3149 	},
3150 
3151 	/* SIIG Cyber Serial Dual PCI 16C550 (10x family): 2S */
3152 	{   "SIIG Cyber Serial Dual PCI 16C550 (10x family)",
3153 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2S550, 0, 0 },
3154 	    {	0xffff,	0xffff,	0,	0	},
3155 	    {
3156 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3157 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
3158 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
3159 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
3160 	    },
3161 	},
3162 
3163 	/* SIIG Cyber Serial Dual PCI 16C650 (10x family): 2S */
3164 	{   "SIIG Cyber Serial Dual PCI 16C650 (10x family)",
3165 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2S650, 0, 0 },
3166 	    {	0xffff,	0xffff,	0,	0	},
3167 	    {
3168 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3169 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
3170 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
3171 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
3172 	    },
3173 	},
3174 
3175 	/* SIIG Cyber Serial Dual PCI 16C850 (10x family): 2S */
3176 	{   "SIIG Cyber Serial Dual PCI 16C850 (10x family)",
3177 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2S850, 0, 0 },
3178 	    {	0xffff,	0xffff,	0,	0	},
3179 	    {
3180 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3181 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
3182 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
3183 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
3184 	    },
3185 	},
3186 
3187 	/* SIIG Cyber 2S1P PCI 16C550 (10x family): 2S, 1P */
3188 	{   "SIIG Cyber 2S1P PCI 16C550 (10x family)",
3189 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2S1P550,
3190 		0, 0 },
3191 	    {	0xffff,	0xffff,	0,	0	},
3192 	    {
3193 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3194 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
3195 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
3196 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
3197 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
3198 	    },
3199 	},
3200 
3201 	/* SIIG Cyber 2S1P PCI 16C650 (10x family): 2S, 1P */
3202 	{   "SIIG Cyber 2S1P PCI 16C650 (10x family)",
3203 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2S1P650,
3204 		0, 0 },
3205 	    {	0xffff,	0xffff,	0,	0	},
3206 	    {
3207 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3208 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
3209 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
3210 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
3211 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
3212 	    },
3213 	},
3214 
3215 	/* SIIG Cyber 2S1P PCI 16C850 (10x family): 2S, 1P */
3216 	{   "SIIG Cyber 2S1P PCI 16C850 (10x family)",
3217 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_2S1P850,
3218 		0, 0 },
3219 	    {	0xffff,	0xffff,	0,	0	},
3220 	    {
3221 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3222 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
3223 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
3224 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
3225 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
3226 	    },
3227 	},
3228 
3229 	/* SIIG Cyber 4S PCI 16C550 (10x family): 4S */
3230 	{   "SIIG Cyber 4S PCI 16C550 (10x family)",
3231 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_4S550, 0, 0 },
3232 	    {	0xffff,	0xffff,	0,	0	},
3233 	    {
3234 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3235 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
3236 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3237 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3238 		{ PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ * 8 },
3239 	    },
3240 	},
3241 
3242 	/* SIIG Cyber 4S PCI 16C650 (10x family): 4S */
3243 	{   "SIIG Cyber 4S PCI 16C650 (10x family)",
3244 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_4S650, 0, 0 },
3245 	    {	0xffff,	0xffff,	0,	0	},
3246 	    {
3247 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3248 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
3249 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3250 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3251 		{ PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ * 8 },
3252 	    },
3253 	},
3254 
3255 	/* SIIG Cyber 4S PCI 16C850 (10x family): 4S */
3256 	{   "SIIG Cyber 4S PCI 16C850 (10x family)",
3257 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER10_4S850, 0, 0 },
3258 	    {	0xffff,	0xffff,	0,	0	},
3259 	    {
3260 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
3261 		    (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
3262 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3263 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3264 		{ PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ * 8 },
3265 	    },
3266 	},
3267 
3268 	/*
3269 	 * SIIG "20x" family boards.
3270 	 */
3271 
3272 	/* SIIG Cyber Serial PCI 16C550 (20x family): 1S */
3273 	{   "SIIG Cyber Serial PCI 16C550 (20x family)",
3274 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_S550, 0, 0 },
3275 	    {	0xffff,	0xffff,	0,	0	},
3276 	    {
3277 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3278 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3279 	    },
3280 	},
3281 
3282 	/* SIIG Cyber Serial PCI 16C650 (20x family): 1S */
3283 	{   "SIIG Cyber Serial PCI 16C650 (20x family)",
3284 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_S650, 0, 0 },
3285 	    {	0xffff,	0xffff,	0,	0	},
3286 	    {
3287 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3288 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3289 	    },
3290 	},
3291 
3292 	/* SIIG Cyber Serial PCI 16C850 (20x family): 1S */
3293 	{   "SIIG Cyber Serial PCI 16C850 (20x family)",
3294 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_S850, 0, 0 },
3295 	    {	0xffff,	0xffff,	0,	0	},
3296 	    {
3297 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3298 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3299 	    },
3300 	},
3301 
3302 	/* SIIG Cyber I/O PCI 16C550 (20x family): 1S, 1P */
3303 	{   "SIIG Cyber I/O PCI 16C550 (20x family)",
3304 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_IO550, 0, 0 },
3305 	    {	0xffff,	0xffff,	0,	0	},
3306 	    {
3307 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3308 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3309 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
3310 	    },
3311 	},
3312 
3313 	/* SIIG Cyber I/O PCI 16C650 (20x family): 1S, 1P */
3314 	{   "SIIG Cyber I/O PCI 16C650 (20x family)",
3315 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_IO650, 0, 0 },
3316 	    {	0xffff,	0xffff,	0,	0	},
3317 	    {
3318 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3319 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3320 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
3321 	    },
3322 	},
3323 
3324 	/* SIIG Cyber I/O PCI 16C850 (20x family): 1S, 1P */
3325 	{   "SIIG Cyber I/O PCI 16C850 (20x family)",
3326 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_IO850, 0, 0 },
3327 	    {	0xffff,	0xffff,	0,	0	},
3328 	    {
3329 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3330 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3331 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
3332 	    },
3333 	},
3334 
3335 	/* SIIG Cyber Parallel PCI (20x family): 1P */
3336 	{   "SIIG Cyber Parallel PCI (20x family)",
3337 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_P, 0, 0 },
3338 	    {	0xffff,	0xffff,	0,	0	},
3339 	    {
3340 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3341 	    },
3342 	},
3343 
3344 	/* SIIG Cyber Parallel Dual PCI (20x family): 2P */
3345 	{   "SIIG Cyber Parallel Dual PCI (20x family)",
3346 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2P, 0, 0 },
3347 	    {	0xffff,	0xffff,	0,	0	},
3348 	    {
3349 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3350 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3351 	    },
3352 	},
3353 
3354 	/* SIIG Cyber Serial Dual PCI 16C550 (20x family): 2S */
3355 	{   "SIIG Cyber Serial Dual PCI 16C550 (20x family)",
3356 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2S550, 0, 0 },
3357 	    {	0xffff,	0xffff,	0,	0	},
3358 	    {
3359 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3360 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3361 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
3362 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
3363 	    },
3364 	},
3365 
3366 	/* SIIG Cyber Serial Dual PCI 16C650 (20x family): 2S */
3367 	{   "SIIG Cyber Serial Dual PCI 16C650 (20x family)",
3368 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2S650, 0, 0 },
3369 	    {	0xffff,	0xffff,	0,	0	},
3370 	    {
3371 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3372 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3373 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
3374 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
3375 	    },
3376 	},
3377 
3378 	/* SIIG Cyber Serial Dual PCI 16C850 (20x family): 2S */
3379 	{   "SIIG Cyber Serial Dual PCI 16C850 (20x family)",
3380 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2S850, 0, 0 },
3381 	    {	0xffff,	0xffff,	0,	0	},
3382 	    {
3383 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3384 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3385 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
3386 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
3387 	    },
3388 	},
3389 
3390 	/* SIIG Cyber 2P1S PCI 16C550 (20x family): 1S, 2P */
3391 	{   "SIIG Cyber 2P1S PCI 16C550 (20x family)",
3392 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2P1S550,
3393 		0, 0 },
3394 	    {	0xffff,	0xffff,	0,	0	},
3395 	    {
3396 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3397 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3398 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
3399 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3400 	    },
3401 	},
3402 
3403 	/* SIIG Cyber 2P1S PCI 16C650 (20x family): 1S, 2P */
3404 	{   "SIIG Cyber 2P1S PCI 16C650 (20x family)",
3405 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2P1S650,
3406 		0, 0 },
3407 	    {	0xffff,	0xffff,	0,	0	},
3408 	    {
3409 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3410 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3411 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
3412 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3413 	    },
3414 	},
3415 
3416 	/* SIIG Cyber 2P1S PCI 16C850 (20x family): 1S, 2P */
3417 	{   "SIIG Cyber 2P1S PCI 16C850 (20x family)",
3418 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2P1S850,
3419 		0, 0 },
3420 	    {	0xffff,	0xffff,	0,	0	},
3421 	    {
3422 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3423 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3424 		{ PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
3425 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3426 	    },
3427 	},
3428 
3429 	/* SIIG Cyber 4S PCI 16C550 (20x family): 4S */
3430 	{   "SIIG Cyber 4S PCI 16C550 (20x family)",
3431 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_4S550, 0, 0 },
3432 	    {	0xffff,	0xffff,	0,	0	},
3433 	    {
3434 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3435 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3436 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3437 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3438 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3439 	    },
3440 	},
3441 
3442 	/* SIIG Cyber 4S PCI 16C650 (20x family): 4S */
3443 	{   "SIIG Cyber 4S PCI 16C650 (20x family)",
3444 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_4S650, 0, 0 },
3445 	    {	0xffff,	0xffff,	0,	0	},
3446 	    {
3447 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3448 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3449 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3450 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3451 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3452 	    },
3453 	},
3454 
3455 	/* SIIG Cyber 4S PCI 16C850 (20x family): 4S */
3456 	{   "SIIG Cyber 4S PCI 16C850 (20x family)",
3457 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_4S850, 0, 0 },
3458 	    {	0xffff,	0xffff,	0,	0	},
3459 	    {
3460 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3461 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3462 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3463 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3464 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3465 	    },
3466 	},
3467 
3468 	/* SIIG Cyber 2S1P PCI 16C550 (20x family): 2S, 1P */
3469 	{   "SIIG Cyber 2S1P PCI 16C550 (20x family)",
3470 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2S1P550,
3471 		0, 0 },
3472 	    {	0xffff,	0xffff,	0,	0	},
3473 	    {
3474 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3475 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3476 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
3477 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
3478 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3479 	    },
3480 	},
3481 
3482 	/* SIIG Cyber 2S1P PCI 16C650 (20x family): 2S, 1P */
3483 	{   "SIIG Cyber 2S1P PCI 16C650 (20x family)",
3484 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2S1P650,
3485 		0, 0 },
3486 	    {	0xffff,	0xffff,	0,	0	},
3487 	    {
3488 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3489 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3490 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
3491 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
3492 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3493 	    },
3494 	},
3495 
3496 	/* SIIG Cyber 2S1P PCI 16C850 (20x family): 2S, 1P */
3497 	{   "SIIG Cyber 2S1P PCI 16C850 (20x family)",
3498 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_CYBER20_2S1P850,
3499 		0, 0 },
3500 	    {	0xffff,	0xffff,	0,	0	},
3501 	    {
3502 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3503 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3504 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
3505 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
3506 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3507 	    },
3508 	},
3509 
3510 	/* SIIG PS8000 PCI 8S 16C550 (20x family): 8S - 16 Byte FIFOs */
3511 	{   "SIIG PS8000 PCI 8S 16C550 (20x family)",
3512 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_PS8000P550, 0, 0 },
3513 	    {	0xffff,	0xffff,	0,	0	},
3514 	    {
3515 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3516 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3517 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3518 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3519 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3520 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3521 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
3522 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
3523 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
3524 	    },
3525 	},
3526 
3527 	/* SIIG PS8000 PCI 8S 16C650 (20x family): 8S - 32 Byte FIFOs */
3528 	{   "SIIG PS8000 PCI 8S 16C650 (20x family)",
3529 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_PS8000P650, 0, 0 },
3530 	    {	0xffff,	0xffff,	0,	0	},
3531 	    {
3532 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3533 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3534 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3535 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3536 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3537 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3538 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
3539 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
3540 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
3541 	    },
3542 	},
3543 
3544 	/* SIIG PS8000 PCI 8S 16C850 (20x family): 8S - 128 Byte FIFOs */
3545 	{   "SIIG PS8000 PCI 8S 16C850 (20x family)",
3546 	    {	PCI_VENDOR_SIIG,	PCI_PRODUCT_SIIG_PS8000P850, 0, 0 },
3547 	    {	0xffff,	0xffff,	0,	0	},
3548 	    {
3549 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
3550 		    (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
3551 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3552 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3553 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
3554 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3555 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
3556 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
3557 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
3558 	    },
3559 	},
3560 
3561 	/*
3562 	 * SUNIX 40XX series of serial/parallel combo cards.
3563 	 * Tested with 4055A and 4065A.
3564 	 */
3565 	{   "SUNIX 400X 1P",
3566 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3567 		PCI_VENDOR_SUNIX, 0x4000 },
3568 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3569 	    {
3570 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3571 	    },
3572 	},
3573 
3574 	{   "SUNIX 401X 2P",
3575 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3576 		PCI_VENDOR_SUNIX, 0x4010 },
3577 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3578 	    {
3579 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3580 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3581 	    },
3582 	},
3583 
3584 	{   "SUNIX 402X 1S",
3585 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3586 		PCI_VENDOR_SUNIX, 0x4020 },
3587 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3588 	    {
3589 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3590 	    },
3591 	},
3592 
3593 	{   "SUNIX 403X 2S",
3594 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3595 		PCI_VENDOR_SUNIX, 0x4030 },
3596 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3597 	    {
3598 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3599 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3600 	    },
3601 	},
3602 
3603 	{   "SUNIX 4036 2S",
3604 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3605 		PCI_VENDOR_SUNIX, 0x0002 },
3606 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3607 	    {
3608 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3609 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3610 	    },
3611 	},
3612 
3613 	{   "SUNIX 405X 4S",
3614 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3615 		PCI_VENDOR_SUNIX, 0x4050 },
3616 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3617 	    {
3618 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3619 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3620 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ},
3621 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ},
3622 	    },
3623 	},
3624 
3625 	{   "SUNIX 406X 8S",
3626 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3627 		PCI_VENDOR_SUNIX, 0x4060 },
3628 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3629 	    {
3630 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3631 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3632 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ},
3633 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ},
3634 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ},
3635 		{ PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
3636 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ},
3637 		{ PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ},
3638 	    },
3639 	},
3640 
3641 	{   "SUNIX 407X 2S/1P",
3642 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3643 		PCI_VENDOR_SUNIX, 0x4070 },
3644 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3645 	    {
3646 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3647 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3648 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3649 	    },
3650 	},
3651 
3652 	{   "SUNIX 408X 2S/2P",
3653 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3654 		PCI_VENDOR_SUNIX, 0x4080 },
3655 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3656 	    {
3657 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3658 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3659 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3660 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
3661 	    },
3662 	},
3663 
3664 	{   "SUNIX 409X 4S/2P",
3665 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3666 		PCI_VENDOR_SUNIX, 0x4090 },
3667 	    {	0xffff,	0xffff,	0xffff,	0xeff0 },
3668 	    {
3669 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3670 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3671 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ},
3672 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ},
3673 		{ PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
3674 		{ PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
3675 	    },
3676 	},
3677 
3678 	/*
3679 	 * Dolphin Peripherals 4036 (dual serial port) card.
3680 	 * (Dolpin 4025 has the same ID but only one port)
3681 	 */
3682 	{   "Dolphin Peripherals 4036",
3683 	    {	PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
3684 		0x0,	0x0	},
3685 	    {	0xffff,	0xffff,	0x0,	0x0	},
3686 	    {
3687 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3688 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3689 	    },
3690 	},
3691 
3692 	/*
3693 	 * XXX no entry because I have no data:
3694 	 * XXX Dolphin Peripherals 4078 (dual serial and single parallel)
3695 	 */
3696 
3697 	/* SD-LAB PCI I/O Card 4S */
3698 	{   "Syba Tech Ltd. PCI-4S",
3699 	    {   PCI_VENDOR_SYBA, PCI_PRODUCT_SYBA_4S,		0, 0	},
3700 	    {	0xffff,	0xffff,					0, 0	},
3701 	    {
3702 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x3e8, COM_FREQ },
3703 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x2e8, COM_FREQ },
3704 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x3f8, COM_FREQ },
3705 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x2f8, COM_FREQ },
3706 	    },
3707 	},
3708 
3709 	/* SD-LAB PCI I/O Card 4S2P */
3710 	{   "Syba Tech Ltd. PCI-4S2P-550-ECP",
3711 	    {   PCI_VENDOR_SYBA, PCI_PRODUCT_SYBA_4S2P,		0, 0	},
3712 	    {	0xffff,	0xffff,					0, 0	},
3713 	    {
3714 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x2e8, COM_FREQ },
3715 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x2f8, COM_FREQ },
3716 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x000, 0x00 },
3717 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x3e8, COM_FREQ },
3718 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x3f8, COM_FREQ },
3719 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x000, 0x00 },
3720 	    },
3721 	},
3722 
3723 	/* SystemBase SB16C1050 UARTs */
3724 	{   "SystemBase SB16C1050",
3725 	    {	PCI_VENDOR_SYSTEMBASE, PCI_PRODUCT_SYSTEMBASE_SB16C1050, 0, 0 },
3726 	    {	0xffff, 0xffff,						 0, 0 },
3727 	    {
3728 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
3729 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
3730 	    },
3731 	},
3732 
3733 	/* SystemBase SB16C1054 UARTs */
3734 	{   "SystemBase SB16C1054",
3735 	    {	PCI_VENDOR_SYSTEMBASE, PCI_PRODUCT_SYSTEMBASE_SB16C1054, 0, 0 },
3736 	    {	0xffff,	0xffff,						 0, 0 },
3737 	    {
3738 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3739 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3740 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
3741 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
3742 	    },
3743 	},
3744 
3745 	/* SystemBase SB16C1058 UARTs */
3746 	{   "SystemBase SB16C1058",
3747 	    {   PCI_VENDOR_SYSTEMBASE, PCI_PRODUCT_SYSTEMBASE_SB16C1058, 0, 0 },
3748 	    {	0xffff,	0xffff,						 0, 0 },
3749 	    {
3750 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3751 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3752 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
3753 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
3754 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ * 8 },
3755 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ * 8 },
3756 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ * 8 },
3757 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ * 8 },
3758 	    },
3759 	},
3760 
3761 	/*
3762 	 * VScom PCI 010L
3763 	 * one lpt
3764 	 * untested
3765 	 */
3766 	{   "VScom PCI-010L",
3767 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI010L,    0, 0 },
3768 	    {	0xffff, 0xffff,					0, 0 },
3769 	    {
3770 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3771 	    },
3772 	},
3773 
3774 	/*
3775 	 * VScom PCI 100L
3776 	 * one com
3777 	 * The one I have defaults to a frequency of 14.7456 MHz which is
3778 	 * jumper J1 set to 2-3.
3779 	 */
3780 	{   "VScom PCI-100L",
3781 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI100L,	0, 0 },
3782 	    {	0xffff, 0xffff,						0, 0 },
3783 	    {
3784 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3785 	    },
3786 	},
3787 
3788 	/*
3789 	 * VScom PCI 110L
3790 	 * one com, one lpt
3791 	 * untested
3792 	 */
3793 	{   "VScom PCI-110L",
3794 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI110L,	0, 0 },
3795 	    {	0xffff, 0xffff,						0, 0 },
3796 	    {
3797 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3798 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3799 	    },
3800 	},
3801 
3802 	/*
3803 	 * VScom PCI-200L has 2 x 16550 UARTS.
3804 	 * The board has a jumper which allows you to select a clock speed
3805 	 * of either 14.7456MHz or 1.8432MHz. By default it runs at
3806 	 * the fast speed.
3807 	 */
3808 	{   "VScom PCI-200L with 2 x 16550 UARTS",
3809 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200L,	0, 0 },
3810 	    {	0xffff, 0xffff,						0, 0 },
3811 	    {
3812 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3813 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3814 	    },
3815 	},
3816 
3817 	/*
3818 	 * VScom PCI-210L
3819 	 * Has a jumper for frequency selection, defaults to 8x as used here
3820 	 * two com, one lpt
3821 	 */
3822 	{   "VScom PCI-210L",
3823 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI210L,	0, 0 },
3824 	    {	0xffff, 0xffff,					0, 0 },
3825 	    {
3826 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3827 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3828 		{ PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
3829 	    },
3830 	},
3831 
3832 	/* VScom PCI-200Li */
3833 	{   "VScom PCI-200Li",
3834 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200LI,	0, 0 },
3835 	    {	0xffff, 0xffff,						0, 0 },
3836 	    {
3837 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
3838 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
3839 	    },
3840 	},
3841 
3842 	/* PCI-400L: VendorID is reported to be 0x10d2 instead of 0x14d2. */
3843 	{   "VScom PCI-400L",
3844 	    {	PCI_VENDOR_MOLEX, PCI_PRODUCT_MOLEX_VSCOM_PCI400L,	0, 0 },
3845 	    {	0xffff, 0xffff,					0, 0 },
3846 	    {
3847 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3848 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3849 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3850 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
3851 	    },
3852 	},
3853 
3854 	{   "VScom PCI-800L",
3855 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI800L,	0, 0 },
3856 	    {	0xffff,	0xffff,	0,	0	},
3857 	    {
3858 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3859 		{ PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3860 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3861 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
3862 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
3863 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
3864 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x20, COM_FREQ * 8 },
3865 		{ PUC_PORT_TYPE_COM, PCI_BAR4, 0x28, COM_FREQ * 8 },
3866 	    },
3867 	},
3868 
3869 	{   "VScom PCI-011H",
3870 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI011H,	0, 0 },
3871 	    {	0xffff, 0xffff,					0, 0 },
3872 	    {
3873 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3874 	    },
3875 	},
3876 
3877 	/*
3878 	 * VScom PCI x10H, 1 lpt.
3879 	 * is the lpt part of VScom 110H, 210H, 410H
3880 	 */
3881 	{   "VScom PCI-x10H",
3882 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCIx10H,	0, 0 },
3883 	    {	0xffff, 0xffff,					0, 0 },
3884 	    {
3885 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3886 	    },
3887 	},
3888 
3889 	/*
3890 	 * VScom PCI 100H, little sister of 800H, 1 com.
3891 	 * also com part of VScom 110H
3892 	 * The one I have defaults to a frequency of 14.7456 MHz which is
3893 	 * jumper J1 set to 2-3.
3894 	 */
3895 	{   "VScom PCI-100H",
3896 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI100H,	0, 0 },
3897 	    {	0xffff, 0xffff,					0, 0 },
3898 	    {
3899 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3900 	    },
3901 	},
3902 
3903 	/*
3904 	 * VScom PCI-800H. Uses 8 16950 UART, behind a PCI chips that offers
3905 	 * 4 com port on PCI device 0 and 4 on PCI device 1. PCI device 0 has
3906 	 * device ID 3 and PCI device 1 device ID 4.
3907 	 */
3908 	{   "VScom PCI-800H",
3909 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI800H,	0, 0 },
3910 	    {	0xffff,	0xffff,	0,	0	},
3911 	    {
3912 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3913 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3914 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
3915 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
3916 	    },
3917 	},
3918 	{   "VScom PCI-800H",
3919 	    {	PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI800H_1,	0, 0 },
3920 	    {	0xffff,	0xffff,	0,	0	},
3921 	    {
3922 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3923 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3924 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
3925 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
3926 	    },
3927 	},
3928         {   "VScom PCI-200H",
3929 	    {   PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200H, 0, 0 },
3930             {   0xffff, 0xffff, 0,      0       },
3931             {
3932                 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3933                 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3934             },
3935         },
3936 
3937 	{   "VScom PCI-010HV2",
3938 	    {   PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI010HV2,	0, 0 },
3939 	    {   0xffff, 0xffff, 0,      0       },
3940 	    {
3941 		{ PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3942 	    },
3943 	},
3944 	{   "VScom PCI-200HV2",
3945 	    {   PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200HV2,	0, 0 },
3946 	    {   0xffff, 0xffff, 0,      0       },
3947 	    {
3948 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3949 		{ PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3950 	    },
3951 	},
3952 
3953 	/* US Robotics (3Com) PCI Modems */
3954 	{   "US Robotics (3Com) 3CP5609 PCI 16550 Modem",
3955 	    {	PCI_VENDOR_USR,	PCI_PRODUCT_USR_3CP5609, 0, 0 },
3956 	    {	0xffff,	0xffff,	0,	0	},
3957 	    {
3958 		{ PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
3959 	    },
3960 	},
3961 
3962 	{ .name = NULL },
3963 };
3964