pucdata.c revision 1.118 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