pucdata.c revision 1.102.2.1 1 /* $NetBSD: pucdata.c,v 1.102.2.1 2019/06/10 22:07:27 christos 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.102.2.1 2019/06/10 22:07:27 christos 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 /* Avlab Technology, Inc. PCI 2 Serial: 2S */
146 { "Avlab PCI 2 Serial",
147 { PCI_VENDOR_AVLAB, PCI_PRODUCT_AVLAB_PCI2S, 0, 0 },
148 { 0xffff, 0xffff, 0, 0 },
149 {
150 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
151 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
152 },
153 },
154
155 /* Avlab Technology, Inc. Low Profile PCI 4 Serial: 4S */
156 { "Avlab Low Profile PCI 4 Serial",
157 { PCI_VENDOR_AVLAB, PCI_PRODUCT_AVLAB_LPPCI4S, 0, 0 },
158 { 0xffff, 0xffff, 0, 0 },
159 {
160 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
161 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
162 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
163 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
164 },
165 },
166
167 /* Avlab Technology, Inc. Low Profile PCI 4 Serial: 4S */
168 { "Avlab Low Profile PCI 4 Serial",
169 { PCI_VENDOR_AVLAB, PCI_PRODUCT_AVLAB_LPPCI4S_2, 0, 0 },
170 { 0xffff, 0xffff, 0, 0 },
171 {
172 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
173 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
174 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
175 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
176 },
177 },
178
179 /*
180 * B&B Electronics MIPort Serial cards.
181 */
182 { "BBELEC ISOLATED_2_PORT",
183 { PCI_VENDOR_BBELEC, PCI_PRODUCT_BBELEC_ISOLATED_2_PORT, 0, 0 },
184 { 0xffff, 0xffff, 0, 0 },
185 {
186 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
187 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
188 },
189 },
190 { "BBELEC ISOLATED_4_PORT",
191 { PCI_VENDOR_BBELEC, PCI_PRODUCT_BBELEC_ISOLATED_4_PORT, 0, 0 },
192 { 0xffff, 0xffff, 0, 0 },
193 {
194 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
195 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
196 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
197 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
198 },
199 },
200 { "BBELEC ISOLATED_8_PORT",
201 { PCI_VENDOR_BBELEC, PCI_PRODUCT_BBELEC_ISOLATED_8_PORT, 0, 0 },
202 { 0xffff, 0xffff, 0, 0 },
203 {
204 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
205 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
206 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
207 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
208 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
209 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
210 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
211 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
212 },
213 },
214
215 /*
216 * Comtrol
217 */
218 { "Comtrol RocketPort 550/8 RJ11 part A",
219 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT550811A,
220 0, 0 },
221 { 0xffff, 0xffff, 0, 0 },
222 {
223 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
224 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
225 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
226 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
227 },
228 },
229 { "Comtrol RocketPort 550/8 RJ11 part B",
230 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT550811B,
231 0, 0 },
232 { 0xffff, 0xffff, 0, 0 },
233 {
234 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
235 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
236 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
237 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
238 },
239 },
240 { "Comtrol RocketPort 550/8 Octa part A",
241 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508OA,
242 0, 0 },
243 { 0xffff, 0xffff, 0, 0 },
244 {
245 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
246 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
247 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
248 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
249 },
250 },
251 { "Comtrol RocketPort 550/8 Octa part B",
252 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508OB,
253 0, 0 },
254 { 0xffff, 0xffff, 0, 0 },
255 {
256 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
257 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
258 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
259 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
260 },
261 },
262 { "Comtrol RocketPort 550/4 RJ45",
263 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5504, 0, 0 },
264 { 0xffff, 0xffff, 0, 0 },
265 {
266 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
267 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
268 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
269 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
270 },
271 },
272 { "Comtrol RocketPort 550/Quad",
273 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT550Q, 0, 0 },
274 { 0xffff, 0xffff, 0, 0 },
275 {
276 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
277 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
278 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
279 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
280 },
281 },
282 { "Comtrol RocketPort 550/16 part A",
283 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT55016A,
284 0, 0 },
285 { 0xffff, 0xffff, 0, 0 },
286 {
287 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
288 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
289 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
290 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
291 },
292 },
293 { "Comtrol RocketPort 550/16 part B",
294 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT55016B,
295 0, 0 },
296 { 0xffff, 0xffff, 0, 0 },
297 {
298 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
299 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
300 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
301 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
302 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ * 4},
303 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ * 4},
304 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ * 4},
305 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ * 4},
306 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x40, COM_FREQ * 4},
307 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x48, COM_FREQ * 4},
308 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x50, COM_FREQ * 4},
309 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x58, COM_FREQ * 4},
310 },
311 },
312 { "Comtrol RocketPort 550/8 part A",
313 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508A,
314 0, 0 },
315 { 0xffff, 0xffff, 0, 0 },
316 {
317 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
318 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
319 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
320 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
321 },
322 },
323 { "Comtrol RocketPort 550/8 part B",
324 { PCI_VENDOR_COMTROL, PCI_PRODUCT_COMTROL_ROCKETPORT5508B,
325 0, 0 },
326 { 0xffff, 0xffff, 0, 0 },
327 {
328 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 4},
329 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 4},
330 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 4},
331 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 4},
332 },
333 },
334
335 /*
336 * Decision PCCOM PCI series. PLX 9052 with 1 or 2 16554 UARTS
337 */
338 /* Decision Computer Inc PCCOM 2 Port RS232/422/485: 2S */
339 { "Decision Computer Inc PCCOM 2 Port RS232/422/485",
340 { PCI_VENDOR_DCI, PCI_PRODUCT_DCI_APCI2, 0x0, 0x0 },
341 { 0xffff, 0xffff, 0x0, 0x0 },
342 {
343 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
344 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ},
345 },
346 },
347
348 /* Decision Computer Inc PCCOM 4 Port RS232/422/485: 4S */
349 { "Decision Computer Inc PCCOM 4 Port RS232/422/485",
350 { PCI_VENDOR_DCI, PCI_PRODUCT_DCI_APCI4, 0x0, 0x0 },
351 { 0xffff, 0xffff, 0x0, 0x0 },
352 {
353 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
354 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ},
355 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x10, COM_FREQ},
356 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x18, COM_FREQ},
357 },
358 },
359
360 /* Decision Computer Inc PCCOM 8 Port RS232/422/485: 8S */
361 { "Decision Computer Inc PCCOM 8 Port RS232/422/485",
362 { PCI_VENDOR_DCI, PCI_PRODUCT_DCI_APCI8, 0x0, 0x0 },
363 { 0xffff, 0xffff, 0x0, 0x0 },
364 {
365 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
366 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ},
367 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x10, COM_FREQ},
368 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x18, COM_FREQ},
369 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x20, COM_FREQ},
370 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x28, COM_FREQ},
371 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x30, COM_FREQ},
372 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x38, COM_FREQ},
373 },
374 },
375
376 /* Digi International Digi Neo 4 Serial */
377 { "Digi International Digi Neo 4 Serial",
378 { PCI_VENDOR_DIGI, PCI_PRODUCT_DIGI_NEO4, 0, 0 },
379 { 0xffff, 0xffff, 0, 0 },
380 {
381 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
382 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
383 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
384 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
385 },
386 },
387
388 /* Digi International Digi Neo 8 Serial */
389 { "Digi International Digi Neo 8 Serial",
390 { PCI_VENDOR_DIGI, PCI_PRODUCT_DIGI_NEO8, 0, 0 },
391 { 0xffff, 0xffff, 0, 0 },
392 {
393 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
394 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
395 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
396 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
397 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
398 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
399 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
400 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
401 },
402 },
403
404 /* Digi International Digi Neo 8 Serial (PCIe) */
405 { "Digi International Digi Neo 8 Serial (PCIe)",
406 { PCI_VENDOR_DIGI, PCI_PRODUCT_DIGI_NEO8_PCIE, 0, 0 },
407 { 0xffff, 0xffff, 0, 0 },
408 {
409 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
410 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
411 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
412 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
413 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
414 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
415 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
416 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
417 },
418 },
419
420 { "EXAR XR17D152",
421 { PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D152, 0, 0 },
422 { 0xffff, 0xffff, 0, 0 },
423 {
424 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
425 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
426 },
427 },
428 { "EXAR XR17D154",
429 { PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D154, 0, 0 },
430 { 0xffff, 0xffff, 0, 0 },
431 {
432 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
433 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
434 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
435 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
436 },
437 },
438
439 /*
440 * Multi-Tech ISI5634PCI/4 4-port modem board.
441 * Has a 4-channel Exar XR17C154 UART, but with bogus product ID in its
442 * config EEPROM.
443 */
444 { "Multi-Tech ISI5634PCI/4",
445 { PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D158, 0x2205, 0x2003 },
446 { 0xffff, 0xffff, 0xffff, 0xffff },
447 {
448 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
449 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
450 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
451 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
452 },
453 },
454
455 { "EXAR XR17D158",
456 { PCI_VENDOR_EXAR, PCI_PRODUCT_EXAR_XR17D158, 0, 0 },
457 { 0xffff, 0xffff, 0, 0 },
458 {
459 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0000, COM_FREQ * 8 },
460 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0200, COM_FREQ * 8 },
461 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0400, COM_FREQ * 8 },
462 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0600, COM_FREQ * 8 },
463 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0800, COM_FREQ * 8 },
464 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0a00, COM_FREQ * 8 },
465 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0c00, COM_FREQ * 8 },
466 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x0e00, COM_FREQ * 8 },
467 },
468 },
469
470 /* IBM SurePOS 300 Series (481033H) serial ports */
471 { "IBM SurePOS 300 Series (481033H)",
472 { PCI_VENDOR_IBM, PCI_PRODUCT_IBM_4810_SCC, 0, 0 },
473 { 0xffff, 0xffff, 0, 0 },
474 {
475 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ }, /* Port C */
476 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ }, /* Port D */
477 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ }, /* Port E */
478 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ }, /* Port F */
479 },
480 },
481
482 /* I-O DATA RSA-PCI: 2S */
483 { "I-O DATA RSA-PCI 2-port serial",
484 { PCI_VENDOR_IODATA, PCI_PRODUCT_IODATA_RSAPCI, 0, 0 },
485 { 0xffff, 0xffff, 0, 0 },
486 {
487 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
488 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
489 },
490 },
491
492 /* Lava Computers 2SP-PCI */
493 { "Lava Computers 2SP-PCI parallel port",
494 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_1P, 0, 0 },
495 { 0xffff, 0xffff, 0, 0 },
496 {
497 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
498 },
499 },
500
501 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
502 { "Lava Computers dual serial port",
503 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_TWOSP_2S, 0, 0 },
504 { 0xffff, 0xfffc, 0, 0 },
505 {
506 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
507 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
508 },
509 },
510
511 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
512 { "Lava Computers Quattro A",
513 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_AB, 0, 0 },
514 { 0xffff, 0xfffc, 0, 0 },
515 {
516 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
517 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
518 },
519 },
520
521 /* Lava Computers 2SP-PCI and Quattro-PCI serial ports */
522 { "Lava Computers Quattro B",
523 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_CD, 0, 0 },
524 { 0xffff, 0xfffc, 0, 0 },
525 {
526 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
527 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
528 },
529 },
530
531 /* Lava Computers DSerial PCI serial ports */
532 { "Lava Computers serial port",
533 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_IOFLEX_2S_0, 0, 0 },
534 { 0xffff, 0xfffc, 0, 0 },
535 {
536 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
537 },
538 },
539
540 /* Lava Computers Quattro-PCI serial ports */
541 { "Lava Quattro-PCI A 4-port serial",
542 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_AB2, 0, 0 },
543 { 0xffff, 0xfffc, 0, 0 },
544 {
545 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
546 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
547 },
548 },
549
550 /* Lava Computers Quattro-PCI serial ports */
551 { "Lava Quattro-PCI B 4-port serial",
552 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_QUATTRO_CD2, 0, 0 },
553 { 0xffff, 0xfffc, 0, 0 },
554 {
555 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
556 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
557 },
558 },
559
560 /* Lava Computers Octopus-550 serial ports */
561 { "Lava Computers Octopus-550 8-port serial",
562 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_OCTOPUS550_0, 0, 0 },
563 { 0xffff, 0xfffc, 0, 0 },
564 {
565 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
566 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
567 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
568 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
569 },
570 },
571
572 /* Lava Computers Octopus-550 serial ports */
573 { "Lava Computers Octopus-550 B 8-port serial",
574 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_OCTOPUS550_1, 0, 0 },
575 { 0xffff, 0xfffc, 0, 0 },
576 {
577 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
578 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
579 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
580 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
581 },
582 },
583
584 /* Lava Computers single port serial PCI card */
585 { "Lava Computers SSERIAL-PCI",
586 { PCI_VENDOR_LAVA, PCI_PRODUCT_LAVA_SSERIAL, 0, 0 },
587 { 0xffff, 0xffff, 0, 0 },
588 {
589 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
590 },
591 },
592
593 /* Actiontec 56K PCI Master */
594 { "Actiontec 56K PCI Master",
595 { PCI_VENDOR_LUCENT, PCI_PRODUCT_LUCENT_VENUSMODEM,
596 0x0, 0x0 },
597 { 0xffff, 0xffff, 0x0, 0x0 },
598 {
599 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
600 },
601 },
602
603 /*
604 * This is the Middle Digital, Inc. PCI-Weasel, which
605 * uses a PCI interface implemented in FPGA.
606 */
607 { "Middle Digital, Inc. Weasel serial port",
608 { PCI_VENDOR_MIDDLE_DIGITAL,
609 PCI_PRODUCT_MIDDLE_DIGITAL_WEASEL_SERIAL, 0, 0 },
610 { 0xffff, 0xffff, 0, 0 },
611 {
612 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
613 },
614 },
615
616 /* Moxa Technologies Co., Ltd. PCI I/O Card 2S RS232 */
617 { "Moxa Technologies, SmartIO CP-102/PCI",
618 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_CP102U, 0, 0 },
619 { 0xffff, 0xffff, 0, 0 },
620 {
621 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
622 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
623 },
624 },
625
626 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */
627 { "Moxa Technologies, SmartIO C104H/PCI",
628 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C104H, 0, 0 },
629 { 0xffff, 0xffff, 0, 0 },
630 {
631 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
632 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
633 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
634 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
635 },
636 },
637
638 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232 */
639 { "Moxa Technologies, SmartIO CP-104/PCI",
640 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_CP104, 0, 0 },
641 { 0xffff, 0xffff, 0, 0 },
642 {
643 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
644 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
645 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
646 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
647 },
648 },
649
650 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232 */
651 { "Moxa Technologies, SmartIO CP-104-V2/PCI",
652 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_CP104V2, 0, 0 },
653 { 0xffff, 0xffff, 0, 0 },
654 {
655 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
656 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
657 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
658 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
659 },
660 },
661
662 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232 */
663 { "Moxa Technologies, SmartIO CP-104-EL/PCIe",
664 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_CP104EL, 0, 0 },
665 { 0xffff, 0xffff, 0, 0 },
666 {
667 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
668 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
669 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
670 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
671 },
672 },
673
674 /* Moxa Technologies Co., Ltd. PCI I/O Card 4S RS232/422/485 */
675 { "Moxa Technologies, SmartIO CP-114/PCI",
676 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_CP114, 0, 0 },
677 { 0xffff, 0xffff, 0, 0 },
678 {
679 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
680 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
681 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
682 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
683 },
684 },
685
686 /* Moxa Technologies Co., Ltd. PCI I/O Card 8S RS232 */
687 { "Moxa Technologies, SmartIO C168H/PCI",
688 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C168H, 0, 0 },
689 { 0xffff, 0xffff, 0, 0 },
690 {
691 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
692 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
693 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
694 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
695 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
696 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
697 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
698 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
699 },
700 },
701
702 /* Moxa Technologies Co., Ltd. PCI I/O Card 8S RS232 */
703 { "Moxa Technologies, SmartIO C168U/PCI",
704 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C168U, 0, 0 },
705 { 0xffff, 0xffff, 0, 0 },
706 {
707 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
708 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
709 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
710 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
711 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
712 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
713 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
714 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
715 },
716 },
717
718 /* Moxa Technologies Co., Ltd. PCI-Express I/O Card 8S RS232 */
719 { "Moxa Technologies, SmartIO C168EL/PCIe",
720 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C168EL, 0, 0 },
721 { 0xffff, 0xffff, 0, 0 },
722 {
723 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
724 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
725 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
726 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
727 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
728 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
729 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
730 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
731 },
732 },
733 /* Moxa Technologies Co., Ltd. PCI-Express I/O Card 8S RS232 */
734 { "Moxa Technologies, SmartIO CP-168EL-A/PCIe",
735 { PCI_VENDOR_MOXA, PCI_PRODUCT_MOXA_C168ELA, 0, 0 },
736 { 0xffff, 0xffff, 0, 0 },
737 {
738 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x000, COM_FREQ * 8 },
739 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x200, COM_FREQ * 8 },
740 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x400, COM_FREQ * 8 },
741 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x600, COM_FREQ * 8 },
742 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x800, COM_FREQ * 8 },
743 { PUC_PORT_TYPE_COM, PCI_BAR1, 0xa00, COM_FREQ * 8 },
744 { PUC_PORT_TYPE_COM, PCI_BAR1, 0xc00, COM_FREQ * 8 },
745 { PUC_PORT_TYPE_COM, PCI_BAR1, 0xe00, COM_FREQ * 8 },
746 },
747 },
748
749 /* NEC PK-UG-X001 K56flex PCI Modem card.
750 NEC MARTH bridge chip and Rockwell RCVDL56ACF/SP using. */
751 { "NEC PK-UG-X001 K56flex PCI Modem",
752 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_PKUGX001, PCI_VENDOR_NEC,
753 0x8014 },
754 { 0xffff, 0xffff, 0xffff, 0xffff },
755 {
756 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
757 },
758 },
759
760 /* NEC PK-UG-X008 */
761 { "NEC PK-UG-X008",
762 { PCI_VENDOR_NEC, PCI_PRODUCT_NEC_PKUGX008, PCI_VENDOR_NEC,
763 0x8012 },
764 { 0xffff, 0xffff, 0xffff, 0xffff },
765 {
766 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ},
767 },
768 },
769
770 /* NetMos 1P PCI : 1P */
771 { "NetMos NM9805 1284 Printer port",
772 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9805, 0, 0 },
773 { 0xffff, 0xffff, 0, 0 },
774 {
775 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
776 },
777 },
778
779 /* NetMos 2P PCI : 2P */
780 { "NetMos NM9815 Dual 1284 Printer port",
781 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9815, 0, 0 },
782 { 0xffff, 0xffff, 0, 0 },
783 {
784 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
785 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
786 },
787 },
788
789 /* NetMos 1S PCI NM9835 : 1S */
790 { "NetMos NM9835 UART",
791 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9835, 0x1000, 0x0001 },
792 { 0xffff, 0xffff, 0xffff, 0xffff },
793 {
794 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
795 },
796 },
797
798 /* NetMos 2S PCI NM9835 : 2S */
799 { "NetMos NM9835 Dual UART",
800 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9835, 0x1000, 0x0002 },
801 { 0xffff, 0xffff, 0xffff, 0xffff },
802 {
803 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
804 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
805 },
806 },
807
808 /* NetMos 2S1P PCI 16C650 : 2S, 1P */
809 { "NetMos NM9835 Dual UART and 1284 Printer port",
810 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9835, 0, 0 },
811 { 0xffff, 0xffff, 0, 0 },
812 {
813 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
814 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
815 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
816 },
817 },
818
819 /* NetMos 4S0P PCI NM9845 : 4S, 0P */
820 { "NetMos NM9845 Quad UART",
821 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0x1000, 0x0004 },
822 { 0xffff, 0xffff, 0xffff, 0xffff },
823 {
824 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
825 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
826 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
827 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
828 },
829 },
830
831 /* NetMos 4S1P PCI NM9845 : 4S, 1P */
832 { "NetMos NM9845 Quad UART and 1284 Printer port",
833 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0x1000, 0x0014 },
834 { 0xffff, 0xffff, 0xffff, 0xffff },
835 {
836 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
837 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
838 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
839 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
840 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
841 },
842 },
843
844 /* NetMos 6S PCI 16C650 : 6S, 0P */
845 { "NetMos NM9845 6 UART",
846 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0x1000, 0x0006 },
847 { 0xffff, 0xffff, 0xffff, 0xffff },
848 {
849 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
850 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
851 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
852 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
853 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
854 { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ },
855 },
856 },
857
858 /* NetMos 4S1P PCI NM9845 : 4S, 1P */
859 { "NetMos NM9845 Quad UART and 1284 Printer port (unknown type)",
860 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9845, 0, 0 },
861 { 0xffff, 0xffff, 0, 0 },
862 {
863 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
864 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
865 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
866 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
867 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
868 },
869 },
870
871 /* NetMos 4S1P PCI NM9855 : 4S, 1P */
872 { "NetMos NM9855 Quad UART and 1284 Printer port (unknown type)",
873 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9855, 0x1000, 0x0014 },
874 { 0xffff, 0xffff, 0xffff, 0xffff },
875 {
876 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
877 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
878 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
879 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
880 { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ },
881 },
882 },
883
884 /* NetMos 6S PCI NM9865 : 1S */
885 { "NetMos NM9865 1 UART",
886 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x1000 },
887 { 0xffff, 0xffff, 0xffff, 0xffff },
888 {
889 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
890 },
891 },
892
893 /* NetMos PCI NM9865 : 1P */
894 { "NetMos NM9865 Single LPT",
895 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x2000 },
896 { 0xffff, 0xffff, 0xffff, 0xffff },
897 {
898 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
899 },
900 },
901
902 /* NetMos 2S PCI NM9865 : 2S */
903 { "NetMos NM9865 2 UART",
904 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3002 },
905 { 0xffff, 0xffff, 0xffff, 0xffff },
906 {
907 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
908 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
909 },
910 },
911
912 /* NetMos 3S PCI NM9865 : 3S */
913 { "NetMos NM9865 3 UART",
914 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3003 },
915 { 0xffff, 0xffff, 0xffff, 0xffff },
916 {
917 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
918 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
919 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
920 },
921 },
922
923 /* NetMos 4S PCI NM9865 : 4S */
924 { "NetMos NM9865 4 UART",
925 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3004 },
926 { 0xffff, 0xffff, 0xffff, 0xffff },
927 {
928 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
929 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
930 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
931 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
932 },
933 },
934
935 /* NetMos PCI NM9865 : 1S 1P */
936 { "NetMos NM9865 Single UART and Single LPT",
937 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3011 },
938 { 0xffff, 0xffff, 0xffff, 0xffff },
939 {
940 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
941 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
942 },
943 },
944
945 /* NetMos PCI NM9865 : 2S 1P */
946 { "NetMos NM9865 Dual UART and Single LPT",
947 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3012 },
948 { 0xffff, 0xffff, 0xffff, 0xffff },
949 {
950 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
951 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
952 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
953 },
954 },
955
956 /* NetMos PCI NM9865 : 2P */
957 { "NetMos NM9865 Dual LPT",
958 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3020 },
959 { 0xffff, 0xffff, 0xffff, 0xffff },
960 {
961 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
962 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
963 },
964 },
965
966 /*
967 * Two 1-port and one 2-port found on a 4-port
968 * card sold as Sunsway/ST Lab I-430.
969 */
970 { "NetMos NM9865 1S",
971 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x1000 },
972 { 0xffff, 0xffff, 0xffff, 0xffff },
973 {
974 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
975 },
976 },
977 { "NetMos NM9865 2S",
978 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9865, 0xa000, 0x3002 },
979 { 0xffff, 0xffff, 0xffff, 0xffff },
980 {
981 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
982 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
983 },
984 },
985
986 /* NetMos PCIe Peripheral Controller :UART part */
987 { "NetMos NM9901 UART",
988 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9901, 0xa000, 0x1000 },
989 { 0xffff, 0xffff, 0xffff, 0xffff },
990 {
991 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
992 },
993 },
994
995 /* NetMos PCIe NM9901 : 1P */
996 { "NetMos NM9901 LPT",
997 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9901, 0xa000, 0x2000 },
998 { 0xffff, 0xffff, 0xffff, 0xffff },
999 {
1000 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1001 },
1002 },
1003
1004 /* NetMos PCIe NM9904 (PCI multi function): 4S */
1005 { "NetMos NM9904 UART",
1006 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9904, 0, 0 },
1007 { 0xffff, 0xffff, 0, 0 },
1008 {
1009 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1010 },
1011 },
1012
1013 /* NetMos PCIe NM9912 */
1014 { "NetMos NM9912 Dual PCI-E UART and 1284 Printer Port",
1015 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9912, 0, 0x1000 },
1016 { 0xffff, 0xffff, 0, 0xffff },
1017 {
1018 { PUC_PORT_TYPE_COM, 0x10, 0x0000, 0 },
1019 },
1020 },
1021
1022 { "NetMos NM9912 Dual PCI-E UART and 1284 Printer Port",
1023 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9912, 0, 0x2000 },
1024 { 0xffff, 0xffff, 0, 0xffff },
1025 {
1026 { PUC_PORT_TYPE_LPT, 0x10, 0x0000, 0 },
1027 },
1028 },
1029
1030 /* NetMos PCIe NM9922 (PCI multi function): 2S */
1031 { "NetMos NM9922 UART",
1032 { PCI_VENDOR_NETMOS, PCI_PRODUCT_NETMOS_NM9922, 0, 0 },
1033 { 0xffff, 0xffff, 0, 0 },
1034 {
1035 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1036 },
1037 },
1038
1039 /*
1040 * Boards with an Oxford Semiconductor chip.
1041 *
1042 * Oxford Semiconductor provides documentation for their chip at:
1043 * <URL:http://www.plxtech.com/products/uart>
1044 *
1045 * As sold by Kouwell <URL:http://www.kouwell.com/>.
1046 * I/O Flex PCI I/O Card Model-223 with 4 serial and 1 parallel ports.
1047 */
1048
1049 /* Oxford Semiconductor OXPCIe952 PCIe 1P */
1050 { "Oxford Semiconductor OXPCIe952 LPT",
1051 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952P,
1052 0, 0},
1053 { 0xffff, 0xffff, 0, 0 },
1054 {
1055 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1056 },
1057 },
1058
1059 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1060 { "Oxford Semiconductor OXPCIe952 UART",
1061 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_0,
1062 0, 0 },
1063 { 0xffff, 0xffff, 0, 0 },
1064 {
1065 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1066 },
1067 },
1068
1069 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1070 { "Oxford Semiconductor OXPCIe952 UART",
1071 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_1,
1072 0, 0 },
1073 { 0xffff, 0xffff, 0, 0 },
1074 {
1075 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1076 },
1077 },
1078
1079 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1080 { "Oxford Semiconductor OXPCIe952 UARTs",
1081 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_2S,
1082 PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_2S },
1083 { 0xffff, 0xffff, 0xffff, 0xffff },
1084 {
1085 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1086 },
1087 },
1088
1089 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1090 { "Oxford Semiconductor OXPCIe952 UART",
1091 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_2,
1092 0, 0 },
1093 { 0xffff, 0xffff, 0, 0 },
1094 {
1095 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1096 },
1097 },
1098
1099 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1100 { "Oxford Semiconductor OXPCIe952 UART",
1101 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_3,
1102 0, 0 },
1103 { 0xffff, 0xffff, 0, 0 },
1104 {
1105 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1106 },
1107 },
1108
1109 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1110 { "Oxford Semiconductor OXPCIe952 UART",
1111 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_4,
1112 0, 0 },
1113 { 0xffff, 0xffff, 0, 0 },
1114 {
1115 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1116 },
1117 },
1118
1119 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1120 { "Oxford Semiconductor OXPCIe952 UART",
1121 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_5,
1122 0, 0 },
1123 { 0xffff, 0xffff, 0, 0 },
1124 {
1125 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1126 },
1127 },
1128
1129 /* Oxford Semiconductor OXPCIe952 PCIe UARTs */
1130 { "Oxford Semiconductor OXPCIe952 UART",
1131 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE952_6,
1132 0, 0 },
1133 { 0xffff, 0xffff, 0, 0 },
1134 {
1135 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1136 },
1137 },
1138
1139 /* Oxford Semiconductor OXPCIe954 PCIe UARTs */
1140 { "Oxford Semiconductor OXPCIe954 UART",
1141 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXPCIE954,
1142 0, 0 },
1143 { 0xffff, 0xffff, 0, 0 },
1144 {
1145 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x1000, COM_FREQ * 0x22 },
1146 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x1200, COM_FREQ * 0x22 },
1147 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x1400, COM_FREQ * 0x22 },
1148 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x1600, COM_FREQ * 0x22 },
1149 },
1150 },
1151
1152 /* Oxford Semiconductor OXmPCI952 PCI UARTs */
1153 { "Oxford Semiconductor OXmPCI952 UARTs",
1154 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41092,
1155 0, 0 },
1156 { 0xffff, 0xffff, 0, 0 },
1157 {
1158 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1159 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1160 },
1161 },
1162
1163 /* Oxford Semiconductor OXuPCI952 950 PCI UARTs */
1164 { "Oxford Semiconductor OXuPCI952 UARTs",
1165 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OXUPCI952,
1166 0, 0 },
1167 { 0xffff, 0xffff, 0, 0 },
1168 {
1169 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1170 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
1171 },
1172 },
1173
1174 /* Oxford Semiconductor OX16PCI952 PCI `950 UARTs - 128 byte FIFOs */
1175 { "Oxford Semiconductor OX16PCI952 UARTs",
1176 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI952,
1177 0, 0 },
1178 { 0xffff, 0xffff, 0, 0 },
1179 {
1180 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1181 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1182 },
1183 },
1184
1185 /* Oxford Semiconductor OX16PCI952 PCI Parallel port */
1186 { "Oxford Semiconductor OX16PCI952 Parallel port",
1187 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI952P,
1188 0, 0 },
1189 { 0xffff, 0xffff, 0, 0 },
1190 {
1191 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1192 },
1193 },
1194
1195 /* InnoSys Keyspan SX Pro OX16PCI954 based 4 UARTs */
1196 { "InnoSys Keyspan SX Pro Serial Card",
1197 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1198 PCI_VENDOR_INNOSYS, 0x5850 },
1199 { 0xffff, 0xffff, 0xffff, 0xffff },
1200 {
1201 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1202 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1203 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
1204 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
1205 },
1206 },
1207
1208 /* I-O DATA RSA-PCI2 two UARTs based on OX16PCI954 */
1209 { "I-O DATA RSA-PCI2 UARTs",
1210 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1211 PCI_VENDOR_IODATA, 0xc070 },
1212 { 0xffff, 0xffff, 0xffff, 0xffff },
1213 {
1214 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1215 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1216 },
1217 },
1218
1219 /* I-O DATA RSA-PCI2 four/eight(1-4) UARTs based on OX16PCI954 */
1220 { "I-O DATA RSA-PCI2/P4 or P8 (1-4) UARTs",
1221 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1222 PCI_VENDOR_IODATA, 0xd007 },
1223 { 0xffff, 0xffff, 0xffff, 0xffff },
1224 {
1225 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1226 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1227 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
1228 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
1229 },
1230 },
1231
1232 /* OEM of Oxford Semiconductor PCI UARTs? */
1233 { "SIIG Cyber 4 PCI 16550",
1234 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1235 PCI_VENDOR_SIIG, 0x2050 },
1236 { 0xffff, 0xffff, 0xffff, 0xffff },
1237 {
1238 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1239 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1240 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10 },
1241 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10 },
1242 },
1243 },
1244
1245 /* OEM of Oxford Semiconductor PCI UARTs? */
1246 { "SIIG Cyber 4S PCI 16C650 (20x family)",
1247 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1248 PCI_VENDOR_SIIG, 0x2051 },
1249 { 0xffff, 0xffff, 0xffff, 0xffff },
1250 {
1251 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1252 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1253 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10 },
1254 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10 },
1255 },
1256 },
1257
1258 /* OEM of Oxford Semiconductor PCI UARTs? */
1259 { "Avlab LP PCI 4S Quartet",
1260 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1261 PCI_VENDOR_AVLAB, 0x2150 },
1262 { 0xffff, 0xffff, 0xffff, 0xffff },
1263 {
1264 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10 },
1265 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10 },
1266 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10 },
1267 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10 },
1268 },
1269 },
1270
1271 /* Oxford Semiconductor OX16PCI954 PCI UARTs */
1272 { "Oxford Semiconductor OX16PCI954 UARTs",
1273 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1274 PCI_VENDOR_OXFORDSEMI, 0 },
1275 { 0xffff, 0xffff, 0xffff, 0 },
1276 {
1277 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1278 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1279 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
1280 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
1281 },
1282 },
1283
1284 /* Oxford Semiconductor OX16PCI954 PCI UARTs (default for 0x9501) */
1285 { "Oxford Semiconductor OX16PCI954 UARTs",
1286 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954,
1287 0, 0 },
1288 { 0xffff, 0xffff, 0, 0 },
1289 {
1290 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ},
1291 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ},
1292 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ},
1293 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ},
1294 },
1295 },
1296
1297 /* I-O DATA RSA-PCI2 eight(5-8) UARTs base on OX16PCI954 */
1298 { "I-O DATA RSA-PCI2/P8 (5-8) UARTs",
1299 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41098,
1300 PCI_VENDOR_IODATA, 0xd007 },
1301 { 0xffff, 0xffff, 0xffff, 0xffff },
1302 {
1303 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
1304 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
1305 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
1306 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
1307 },
1308 },
1309
1310 /* Exsys EX-41098, second part of SIIG Cyber 8S PCI Card */
1311 { "Exsys EX-41098",
1312 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_EXSYS_EX41098,
1313 PCI_VENDOR_SIIG, 0x2082 },
1314 { 0xffff, 0xffff, 0xffff, 0xffff },
1315 {
1316 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 10},
1317 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 10},
1318 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 10},
1319 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 10},
1320 },
1321 },
1322
1323 /* Oxford Semiconductor OX16PCI954 PCI Parallel port */
1324 { "Oxford Semiconductor OX16PCI954 Parallel port",
1325 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI954P,
1326 0, 0 },
1327 { 0xffff, 0xffff, 0, 0 },
1328 {
1329 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
1330 },
1331 },
1332
1333 /* EXSYS EX-41098-2 UARTs */
1334 { "EXSYS EX-41098-2 UARTs",
1335 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI958,
1336 PCI_VENDOR_OXFORDSEMI, 0x0671 },
1337 { 0xffff, 0xffff, 0xffff, 0xffff },
1338 {
1339 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ},
1340 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ},
1341 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ},
1342 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ},
1343 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ},
1344 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ},
1345 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ},
1346 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ},
1347 },
1348 },
1349
1350 /* Oxford Semiconductor OX16PCI958 UARTs (wildcard)*/
1351 { "Oxford Semiconductor OX16PCI958 UARTs",
1352 { PCI_VENDOR_OXFORDSEMI, PCI_PRODUCT_OXFORDSEMI_OX16PCI958,
1353 0, 0 },
1354 { 0xffff, 0xffff, 0, 0 },
1355 {
1356 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 10},
1357 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 10},
1358 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 10},
1359 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 10},
1360 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 10},
1361 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 10},
1362 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 10},
1363 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 10},
1364 },
1365 },
1366
1367 { "SUNIX 5008 1P",
1368 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1369 0x1fd4, 0x0100 },
1370 { 0xffff, 0xffff, 0xffff, 0xeff0 },
1371 {
1372 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1373 },
1374 },
1375
1376 { "SUNIX 5016 8S",
1377 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1378 0x1fd4, 0x0010 },
1379 { 0xffff, 0xffff, 0xffff, 0xffff },
1380 {
1381 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1382 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1383 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
1384 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
1385 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8},
1386 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ * 8},
1387 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x10, COM_FREQ * 8},
1388 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x18, COM_FREQ * 8},
1389 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x20, COM_FREQ * 8},
1390 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x28, COM_FREQ * 8},
1391 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x30, COM_FREQ * 8},
1392 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x38, COM_FREQ * 8},
1393 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x40, COM_FREQ * 8},
1394 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x48, COM_FREQ * 8},
1395 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x50, COM_FREQ * 8},
1396 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x58, COM_FREQ * 8},
1397 },
1398 },
1399
1400 { "SUNIX 5027 1S",
1401 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1402 0x1fd4, 0x0001 },
1403 { 0xffff, 0xffff, 0xffff, 0xffff },
1404 {
1405 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1406 },
1407 },
1408
1409 { "SUNIX 5037 2S",
1410 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1411 0x1fd4, 0x0002 },
1412 { 0xffff, 0xffff, 0xffff, 0xffff },
1413 {
1414 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1415 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1416 },
1417 },
1418
1419 { "SUNIX 5056 4S",
1420 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1421 0x1fd4, 0x0004 },
1422 { 0xffff, 0xffff, 0xffff, 0xffff },
1423 {
1424 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1425 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1426 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
1427 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
1428 },
1429 },
1430
1431 { "SUNIX 5066 8S",
1432 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1433 0x1fd4, 0x0008 },
1434 { 0xffff, 0xffff, 0xffff, 0xffff },
1435 {
1436 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1437 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1438 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
1439 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
1440 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8},
1441 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ * 8},
1442 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x10, COM_FREQ * 8},
1443 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x18, COM_FREQ * 8},
1444 },
1445 },
1446
1447 { "SUNIX 5069 1S / 1P",
1448 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1449 0x1fd4, 0x0101 },
1450 { 0xffff, 0xffff, 0xffff, 0xeff0 },
1451 {
1452 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1453 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1454 },
1455 },
1456
1457 { "SUNIX 5079 2S / 1P",
1458 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1459 0x1fd4, 0x0102 },
1460 { 0xffff, 0xffff, 0xffff, 0xffff },
1461 {
1462 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1463 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1464 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1465 },
1466 },
1467
1468 { "SUNIX 5099 4S / 1P",
1469 { PCI_VENDOR_SUNIX2, PCI_PRODUCT_SUNIX2_SER5XXXX,
1470 0x1fd4, 0x0104 },
1471 { 0xffff, 0xffff, 0xffff, 0xffff },
1472 {
1473 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
1474 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
1475 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8},
1476 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8},
1477 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1478 },
1479 },
1480
1481 /*
1482 * XXX no entry because I have no data:
1483 * XXX Dolphin Peripherals 4006 (single parallel)
1484 */
1485
1486 /*
1487 * Dolphin Peripherals 4014 (dual parallel port) card. PLX 9050, with
1488 * a seemingly-lame EEPROM setup that puts the Dolphin IDs
1489 * into the subsystem fields, and claims that it's a
1490 * network/misc (0x02/0x80) device.
1491 */
1492 { "Dolphin Peripherals 4014",
1493 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0xd84d, 0x6810 },
1494 { 0xffff, 0xffff, 0xffff, 0xffff },
1495 {
1496 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
1497 { PUC_PORT_TYPE_LPT, PCI_BAR5, 0x00, 0x00 },
1498 },
1499 },
1500
1501 /*
1502 * XXX Dolphin Peripherals 4025 (single serial)
1503 * (clashes with Dolphin Peripherals 4036 (2s variant)
1504 */
1505
1506 /*
1507 * Dolphin Peripherals 4035 (dual serial port) card. PLX 9050, with
1508 * a seemingly-lame EEPROM setup that puts the Dolphin IDs
1509 * into the subsystem fields, and claims that it's a
1510 * network/misc (0x02/0x80) device.
1511 */
1512 { "Dolphin Peripherals 4035",
1513 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0xd84d, 0x6808 },
1514 { 0xffff, 0xffff, 0xffff, 0xffff },
1515 {
1516 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1517 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1518 },
1519 },
1520
1521 /*
1522 * Nanjing QinHeng Electronics
1523 * Products based on CH353 chip which can be
1524 * configured to provide various combinations
1525 * including 2 serial ports and a parallel port
1526 * or 4 serial ports (using a CH432 parallel to
1527 * 2 serial port converter. Product codes from
1528 * documentation (and physical 2 port serial card)
1529 */
1530 { "Nanjing QinHeng Electronics CH352",
1531 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_2S,
1532 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_2S },
1533 { 0xffff, 0xffff, 0xffff, 0xffff },
1534 {
1535 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1536 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1537 },
1538 },
1539
1540 { "Nanjing QinHeng Electronics CH352",
1541 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_1S1P,
1542 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH352_1S1P },
1543 { 0xffff, 0xffff, 0xffff, 0xffff },
1544 {
1545 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1546 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1547 },
1548 },
1549
1550 { "Nanjing QinHeng Electronics CH353",
1551 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_4S,
1552 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_4S },
1553 { 0xffff, 0xffff, 0xffff, 0xffff },
1554 {
1555 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1556 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1557 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1558 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1559 },
1560 },
1561
1562 { "Nanjing QinHeng Electronics CH353",
1563 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_2S1P,
1564 PCI_VENDOR_QINHENG, 0x3253 },
1565 { 0xffff, 0xffff, 0xffff, 0xffff },
1566 {
1567 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1568 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1569 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
1570 },
1571 },
1572
1573 { "Nanjing QinHeng Electronics CH353 (fixed address)",
1574 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_2S1PAR,
1575 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH353_2S1PAR },
1576 { 0xffff, 0xffff, 0xffff, 0xffff },
1577 {
1578 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1579 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1580 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
1581 },
1582 },
1583
1584 { "Nanjing QinHeng Electronics CH355",
1585 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH355_4S,
1586 PCI_VENDOR_QINHENG, 0x3473 },
1587 { 0xffff, 0xffff, 0xffff, 0xffff },
1588 {
1589 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1590 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1591 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1592 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1593 },
1594 },
1595
1596 { "Nanjing QinHeng Electronics CH356",
1597 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_4S1P,
1598 PCI_VENDOR_QINHENG, 0x3473 },
1599 { 0xffff, 0xffff, 0xffff, 0xffff },
1600 {
1601 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1602 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1603 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1604 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1605 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
1606 },
1607 },
1608
1609 { "Nanjing QinHeng Electronics CH356",
1610 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_6S,
1611 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_6S },
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 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1618 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
1619 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
1620 },
1621 },
1622
1623 { "Nanjing QinHeng Electronics CH356",
1624 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_8S,
1625 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH356_8S },
1626 { 0xffff, 0xffff, 0xffff, 0xffff },
1627 {
1628 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1629 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1630 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1631 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1632 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
1633 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
1634 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ },
1635 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ },
1636 },
1637 },
1638
1639 { "Nanjing QinHeng Electronics CH357",
1640 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH357_4S,
1641 PCI_VENDOR_QINHENG, 0x5053 },
1642 { 0xffff, 0xffff, 0xffff, 0xffff },
1643 {
1644 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1645 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1646 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1647 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1648 },
1649 },
1650
1651 { "Nanjing QinHeng Electronics CH358",
1652 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_4S1P,
1653 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_4S1P },
1654 { 0xffff, 0xffff, 0xffff, 0xffff },
1655 {
1656 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1657 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1658 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1659 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1660 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
1661 },
1662 },
1663
1664 { "Nanjing QinHeng Electronics CH358",
1665 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_8S,
1666 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH358_8S },
1667 { 0xffff, 0xffff, 0xffff, 0xffff },
1668 {
1669 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1670 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1671 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1672 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1673 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
1674 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ },
1675 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ },
1676 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ },
1677 },
1678 },
1679
1680 { "Nanjing QinHeng Electronics CH359",
1681 { PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH359_16S,
1682 PCI_VENDOR_QINHENG, PCI_PRODUCT_QINHENG_CH359_16S },
1683 { 0xffff, 0xffff, 0xffff, 0xffff },
1684 {
1685 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1686 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ },
1687 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ },
1688 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ },
1689 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
1690 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ },
1691 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ },
1692 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x08, COM_FREQ },
1693 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
1694 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ },
1695 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x20, COM_FREQ },
1696 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x30, COM_FREQ },
1697 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
1698 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ },
1699 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x28, COM_FREQ },
1700 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x38, COM_FREQ },
1701 },
1702 },
1703
1704 { "Nanjing QinHeng Electronics CH382",
1705 { PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S,
1706 PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S },
1707 { 0xffff, 0xffff, 0xffff, 0xffff },
1708 {
1709 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
1710 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
1711 },
1712 },
1713
1714 { "Nanjing QinHeng Electronics CH382",
1715 { PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S1P,
1716 PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH382_2S1P },
1717 { 0xffff, 0xffff, 0xffff, 0xffff },
1718 {
1719 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
1720 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
1721 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1722 },
1723 },
1724
1725 { "Nanjing QinHeng Electronics CH384",
1726 { PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S,
1727 PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S },
1728 { 0xffff, 0xffff, 0xffff, 0xffff },
1729 {
1730 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
1731 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
1732 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xd0, COM_FREQ },
1733 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xd8, COM_FREQ },
1734 },
1735 },
1736
1737 { "Nanjing QinHeng Electronics CH384",
1738 { PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S1P,
1739 PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_4S1P },
1740 { 0xffff, 0xffff, 0xffff, 0xffff },
1741 {
1742 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
1743 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
1744 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xd0, COM_FREQ },
1745 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xd8, COM_FREQ },
1746 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
1747 },
1748 },
1749
1750 { "Nanjing QinHeng Electronics CH384",
1751 { PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_8S,
1752 PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_8S },
1753 { 0xffff, 0xffff, 0xffff, 0xffff },
1754 {
1755 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1756 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ },
1757 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ },
1758 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ },
1759 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
1760 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ },
1761 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ },
1762 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ },
1763 },
1764 },
1765
1766 { "Nanjing QinHeng Electronics CH384",
1767 { PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_28S,
1768 PCI_VENDOR_QINHENG2, PCI_PRODUCT_QINHENG2_CH384_28S },
1769 { 0xffff, 0xffff, 0xffff, 0xffff },
1770 {
1771 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc0, COM_FREQ },
1772 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xc8, COM_FREQ },
1773 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xd0, COM_FREQ },
1774 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xd8, COM_FREQ },
1775 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1776 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ },
1777 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ },
1778 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ },
1779 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
1780 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ },
1781 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ },
1782 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ },
1783 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x40, COM_FREQ },
1784 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x50, COM_FREQ },
1785 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x60, COM_FREQ },
1786 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x70, COM_FREQ },
1787 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x48, COM_FREQ },
1788 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x58, COM_FREQ },
1789 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x68, COM_FREQ },
1790 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x78, COM_FREQ },
1791 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x80, COM_FREQ },
1792 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x90, COM_FREQ },
1793 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xa0, COM_FREQ },
1794 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xb0, COM_FREQ },
1795 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x88, COM_FREQ },
1796 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x98, COM_FREQ },
1797 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xa8, COM_FREQ },
1798 { PUC_PORT_TYPE_COM, PCI_BAR0, 0xb8, COM_FREQ },
1799 },
1800 },
1801
1802 /* Intel 82946GZ/GL KT */
1803 { "Intel 82946GZ/GL KT",
1804 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82946GZ_KT, 0, 0 },
1805 { 0xffff, 0xffff, 0, 0 },
1806 {
1807 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1808 },
1809 },
1810
1811 /* Intel P965/G965 KT */
1812 { "Intel P965/G965 KT",
1813 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82P965_KT, 0, 0 },
1814 { 0xffff, 0xffff, 0, 0 },
1815 {
1816 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1817 },
1818 },
1819
1820 /* Intel PM965/GM965 KT */
1821 { "Intel PM965/GM965 KT",
1822 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82965PM_KT, 0, 0 },
1823 { 0xffff, 0xffff, 0, 0 },
1824 {
1825 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1826 },
1827 },
1828
1829 /* Intel GME965/GLE965 KT */
1830 { "Intel GME965/GLE965 KT",
1831 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82965GME_KT, 0, 0 },
1832 { 0xffff, 0xffff, 0, 0 },
1833 {
1834 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1835 },
1836 },
1837
1838 /* Intel Q963/Q965 KT */
1839 { "Intel Q963/Q965 KT",
1840 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q965_KT, 0, 0 },
1841 { 0xffff, 0xffff, 0, 0 },
1842 {
1843 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1844 },
1845 },
1846
1847 /* Intel G33/G31/P35/P31 KT */
1848 { "Intel G33/G31/P35/P31 KT",
1849 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82G33_KT, 0, 0 },
1850 { 0xffff, 0xffff, 0, 0 },
1851 {
1852 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1853 },
1854 },
1855
1856 /* Intel Q35 KT */
1857 { "Intel Q35 KT",
1858 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q35_KT, 0, 0 },
1859 { 0xffff, 0xffff, 0, 0 },
1860 {
1861 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1862 },
1863 },
1864
1865 /* Intel Q33 KT */
1866 { "Intel Q33 KT",
1867 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q33_KT, 0, 0 },
1868 { 0xffff, 0xffff, 0, 0 },
1869 {
1870 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1871 },
1872 },
1873
1874 /* Intel X38 KT */
1875 { "Intel X38 KT",
1876 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82X38_KT, 0, 0 },
1877 { 0xffff, 0xffff, 0, 0 },
1878 {
1879 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1880 },
1881 },
1882
1883 /* Intel 3200 KT */
1884 { "Intel 3200 KT",
1885 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_3200_KT, 0, 0 },
1886 { 0xffff, 0xffff, 0, 0 },
1887 {
1888 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1889 },
1890 },
1891
1892 /* Intel GM45 KT */
1893 { "Intel GM45 KT",
1894 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82GM45_KT, 0, 0 },
1895 { 0xffff, 0xffff, 0, 0 },
1896 {
1897 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1898 },
1899 },
1900
1901 /* Intel Q45 KT */
1902 { "Intel Q45 KT",
1903 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q45_KT, 0, 0 },
1904 { 0xffff, 0xffff, 0, 0 },
1905 {
1906 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1907 },
1908 },
1909
1910 /* Intel Q45 KT (again) */
1911 { "Intel Q45 KT",
1912 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82Q45_KT_1, 0, 0 },
1913 { 0xffff, 0xffff, 0, 0 },
1914 {
1915 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1916 },
1917 },
1918 /* Intel 5 Series and Intel 3400 Series KT */
1919 { "Intel 5 Series KT",
1920 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_3400_KT, 0, 0 },
1921 { 0xffff, 0xffff, 0, 0 },
1922 {
1923 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1924 },
1925 },
1926
1927 /* Intel 6 Series KT */
1928 { "Intel 6 Series KT",
1929 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_6SERIES_KT, 0, 0 },
1930 { 0xffff, 0xffff, 0, 0 },
1931 {
1932 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1933 },
1934 },
1935
1936 /* Intel 7 Series KT */
1937 { "Intel 7 Series KT",
1938 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_7SERIES_KT, 0, 0 },
1939 { 0xffff, 0xffff, 0, 0 },
1940 {
1941 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1942 },
1943 },
1944
1945 /* Intel 8 Series KT */
1946 { "Intel 8 Series KT",
1947 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_8SERIES_KT, 0, 0 },
1948 { 0xffff, 0xffff, 0, 0 },
1949 {
1950 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1951 },
1952 },
1953
1954 /* Intel 9 Series KT */
1955 { "Intel 9 Series KT",
1956 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_9SERIES_KT, 0, 0 },
1957 { 0xffff, 0xffff, 0, 0 },
1958 {
1959 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1960 },
1961 },
1962
1963 /* Intel 100 Series KT */
1964 { "Intel 100 Series KT",
1965 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_100SERIES_KT, 0, 0 },
1966 { 0xffff, 0xffff, 0, 0 },
1967 {
1968 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1969 },
1970 },
1971
1972 /* Intel 200 Series KT */
1973 { "Intel 200 Series KT",
1974 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_2HS_KT, 0, 0 },
1975 { 0xffff, 0xffff, 0, 0 },
1976 {
1977 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1978 },
1979 },
1980
1981 /* Intel 300 Series KT */
1982 { "Intel 300 Series KT",
1983 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_3HS_KT, 0, 0 },
1984 { 0xffff, 0xffff, 0, 0 },
1985 {
1986 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1987 },
1988 },
1989
1990 /* Intel C600/X79 Series KT */
1991 { "Intel C600/X79 Series KT",
1992 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_C600_KT, 0, 0 },
1993 { 0xffff, 0xffff, 0, 0 },
1994 {
1995 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
1996 },
1997 },
1998
1999 /* Intel Core 4G (mobile) KT */
2000 { "Intel Core 4G (mobile) KT",
2001 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_CORE4G_M_KT, 0, 0 },
2002 { 0xffff, 0xffff, 0, 0 },
2003 {
2004 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2005 },
2006 },
2007
2008 /* Intel EG20T UART */
2009 { "Intel EG20T UART #0",
2010 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_0, 0, 0 },
2011 { 0xffff, 0xffff, 0, 0 },
2012 {
2013 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2014 },
2015 },
2016
2017 /* Intel EG20T UART */
2018 { "Intel EG20T UART #1",
2019 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_1, 0, 0 },
2020 { 0xffff, 0xffff, 0, 0 },
2021 {
2022 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2023 },
2024 },
2025
2026 /* Intel EG20T UART */
2027 { "Intel EG20T UART #2",
2028 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_2, 0, 0 },
2029 { 0xffff, 0xffff, 0, 0 },
2030 {
2031 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2032 },
2033 },
2034
2035 /* Intel EG20T UART */
2036 { "Intel EG20T UART #3",
2037 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_EG20T_UART_3, 0, 0 },
2038 { 0xffff, 0xffff, 0, 0 },
2039 {
2040 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2041 },
2042 },
2043
2044 /* Intel Quark X1000 UART */
2045 { "Intel Quark X1000 UART",
2046 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_X1000_HS_UART, 0, 0 },
2047 { 0xffff, 0xffff, 0, 0 },
2048 {
2049 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, 44236800 },
2050 },
2051 },
2052
2053 /* Intel S1200 UART */
2054 { "Intel S1200 UART",
2055 { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_S1200_UART, 0, 0 },
2056 { 0xffff, 0xffff, 0, 0 },
2057 {
2058 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2059 },
2060 },
2061
2062 /* VScom PCI-200: 2S */
2063 { "VScom PCI-200",
2064 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_PCI_200,
2065 PCI_VENDOR_PLX, 0x1103 },
2066 { 0xffff, 0xffff, 0xffff, 0xffff },
2067 {
2068 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2069 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2070 },
2071 },
2072
2073 /* VScom PCI-400: 4S */
2074 { "VScom PCI-400",
2075 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_PCI_400,
2076 PCI_VENDOR_PLX, 0x1077 },
2077 { 0xffff, 0xffff, 0xffff, 0xffff },
2078 {
2079 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2080 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
2081 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
2082 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
2083 },
2084 },
2085
2086 /* VScom PCI-800: 8S */
2087 { "VScom PCI-800",
2088 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_PCI_800,
2089 PCI_VENDOR_PLX, 0x1076 },
2090 { 0xffff, 0xffff, 0xffff, 0xffff },
2091 {
2092 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2093 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 8 },
2094 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 8 },
2095 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 8 },
2096 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 8 },
2097 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 8 },
2098 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 8 },
2099 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 8 },
2100 },
2101 },
2102
2103 /*
2104 * Perle PCI-RAS 4 Modem ports
2105 */
2106 { "Perle Systems PCI-RAS 4 modem ports",
2107 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9030, 0x155f, 0xf001 },
2108 { 0xffff, 0xffff, 0xffff, 0xffff },
2109 {
2110 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2111 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2112 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2113 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2114 },
2115 },
2116
2117 /*
2118 * Perle PCI-RASV92 4 Modem ports
2119 */
2120 { "Perle Systems PCI-RASV92 4 modem ports",
2121 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x155f, 0xf001 },
2122 { 0xffff, 0xffff, 0xffff, 0xffff },
2123 {
2124 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2125 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2126 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2127 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2128 },
2129 },
2130
2131 /*
2132 * Perle PCI-RAS 8 Modem ports
2133 */
2134 { "Perle Systems PCI-RAS 8 modem ports",
2135 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9030, 0x155f, 0xf010 },
2136 { 0xffff, 0xffff, 0xffff, 0xffff },
2137 {
2138 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2139 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2140 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2141 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2142 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 4 },
2143 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 4 },
2144 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 4 },
2145 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 4 },
2146 },
2147 },
2148
2149 /*
2150 * Perle PCI-RASV92 8 Modem ports
2151 */
2152 { "Perle Systems PCI-RASV92 8 modem ports",
2153 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x155f, 0xf010 },
2154 { 0xffff, 0xffff, 0xffff, 0xffff },
2155 {
2156 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2157 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2158 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2159 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2160 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 4 },
2161 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 4 },
2162 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 4 },
2163 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 4 },
2164 },
2165 },
2166
2167 /*
2168 * Boca Research Turbo Serial 654 (4 serial port) card.
2169 * Appears to be the same as Chase Research PLC PCI-FAST4
2170 * and Perle PCI-FAST4 Multi-Port serial cards.
2171 */
2172 { "Boca Research Turbo Serial 654",
2173 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x12e0, 0x0031 },
2174 { 0xffff, 0xffff, 0xffff, 0xffff },
2175 {
2176 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2177 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2178 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2179 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2180 },
2181 },
2182
2183 /*
2184 * Boca Research Turbo Serial 658 (8 serial port) card.
2185 * Appears to be the same as Chase Research PLC PCI-FAST8
2186 * and Perle PCI-FAST8 Multi-Port serial cards.
2187 */
2188 { "Boca Research Turbo Serial 658",
2189 { PCI_VENDOR_PLX, PCI_PRODUCT_PLX_9050, 0x12e0, 0x0021 },
2190 { 0xffff, 0xffff, 0xffff, 0xffff },
2191 {
2192 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 4 },
2193 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x08, COM_FREQ * 4 },
2194 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x10, COM_FREQ * 4 },
2195 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x18, COM_FREQ * 4 },
2196 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x20, COM_FREQ * 4 },
2197 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x28, COM_FREQ * 4 },
2198 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x30, COM_FREQ * 4 },
2199 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x38, COM_FREQ * 4 },
2200 },
2201 },
2202
2203 /*
2204 * SIIG Boards.
2205 *
2206 * SIIG provides documentation for their boards at:
2207 * <URL:http://www.siig.com/driver.htm>
2208 *
2209 * Please excuse the weird ordering, it's the order they
2210 * use in their documentation.
2211 */
2212
2213 /*
2214 * SIIG "10x" family boards.
2215 */
2216
2217 /* SIIG Cyber Serial PCI 16C550 (10x family): 1S */
2218 { "SIIG Cyber Serial PCI 16C550 (10x family)",
2219 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_S550, 0, 0 },
2220 { 0xffff, 0xffff, 0, 0 },
2221 {
2222 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2223 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR1 },
2224 },
2225 },
2226
2227 /* SIIG Cyber Serial PCI 16C650 (10x family): 1S */
2228 { "SIIG Cyber Serial PCI 16C650 (10x family)",
2229 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_S650, 0, 0 },
2230 { 0xffff, 0xffff, 0, 0 },
2231 {
2232 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2233 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR1 },
2234 },
2235 },
2236
2237 /* SIIG Cyber Serial PCI 16C850 (10x family): 1S */
2238 { "SIIG Cyber Serial PCI 16C850 (10x family)",
2239 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_S850, 0, 0 },
2240 { 0xffff, 0xffff, 0, 0 },
2241 {
2242 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2243 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR1 },
2244 },
2245 },
2246
2247 /* SIIG Cyber I/O PCI 16C550 (10x family): 1S, 1P */
2248 { "SIIG Cyber I/O PCI 16C550 (10x family)",
2249 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_IO550, 0, 0 },
2250 { 0xffff, 0xffff, 0, 0 },
2251 {
2252 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2253 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
2254 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2255 },
2256 },
2257
2258 /* SIIG Cyber I/O PCI 16C650 (10x family): 1S, 1P */
2259 { "SIIG Cyber I/O PCI 16C650 (10x family)",
2260 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_IO650, 0, 0 },
2261 { 0xffff, 0xffff, 0, 0 },
2262 {
2263 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2264 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
2265 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2266 },
2267 },
2268
2269 /* SIIG Cyber I/O PCI 16C850 (10x family): 1S, 1P */
2270 { "SIIG Cyber I/O PCI 16C850 (10x family)",
2271 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_IO850, 0, 0 },
2272 { 0xffff, 0xffff, 0, 0 },
2273 {
2274 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2275 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
2276 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2277 },
2278 },
2279
2280 /* SIIG Cyber Parallel PCI (10x family): 1P */
2281 { "SIIG Cyber Parallel PCI (10x family)",
2282 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_P, 0, 0 },
2283 { 0xffff, 0xffff, 0, 0 },
2284 {
2285 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2286 },
2287 },
2288
2289 /* SIIG Cyber Parallel Dual PCI (10x family): 2P */
2290 { "SIIG Cyber Parallel Dual PCI (10x family)",
2291 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2P, 0, 0 },
2292 { 0xffff, 0xffff, 0, 0 },
2293 {
2294 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2295 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2296 },
2297 },
2298
2299 /* SIIG Cyber Serial Dual PCI 16C550 (10x family): 2S */
2300 { "SIIG Cyber Serial Dual PCI 16C550 (10x family)",
2301 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2S550, 0, 0 },
2302 { 0xffff, 0xffff, 0, 0 },
2303 {
2304 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2305 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
2306 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
2307 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
2308 },
2309 },
2310
2311 /* SIIG Cyber Serial Dual PCI 16C650 (10x family): 2S */
2312 { "SIIG Cyber Serial Dual PCI 16C650 (10x family)",
2313 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2S650, 0, 0 },
2314 { 0xffff, 0xffff, 0, 0 },
2315 {
2316 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2317 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
2318 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
2319 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
2320 },
2321 },
2322
2323 /* SIIG Cyber Serial Dual PCI 16C850 (10x family): 2S */
2324 { "SIIG Cyber Serial Dual PCI 16C850 (10x family)",
2325 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2S850, 0, 0 },
2326 { 0xffff, 0xffff, 0, 0 },
2327 {
2328 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2329 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
2330 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
2331 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
2332 },
2333 },
2334
2335 /* SIIG Cyber 2S1P PCI 16C550 (10x family): 2S, 1P */
2336 { "SIIG Cyber 2S1P PCI 16C550 (10x family)",
2337 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2S1P550,
2338 0, 0 },
2339 { 0xffff, 0xffff, 0, 0 },
2340 {
2341 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2342 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
2343 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
2344 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
2345 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2346 },
2347 },
2348
2349 /* SIIG Cyber 2S1P PCI 16C650 (10x family): 2S, 1P */
2350 { "SIIG Cyber 2S1P PCI 16C650 (10x family)",
2351 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2S1P650,
2352 0, 0 },
2353 { 0xffff, 0xffff, 0, 0 },
2354 {
2355 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2356 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
2357 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
2358 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
2359 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2360 },
2361 },
2362
2363 /* SIIG Cyber 2S1P PCI 16C850 (10x family): 2S, 1P */
2364 { "SIIG Cyber 2S1P PCI 16C850 (10x family)",
2365 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_2S1P850,
2366 0, 0 },
2367 { 0xffff, 0xffff, 0, 0 },
2368 {
2369 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2370 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR2 },
2371 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00,
2372 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR3 },
2373 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2374 },
2375 },
2376
2377 /* SIIG Cyber 4S PCI 16C550 (10x family): 4S */
2378 { "SIIG Cyber 4S PCI 16C550 (10x family)",
2379 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_4S550, 0, 0 },
2380 { 0xffff, 0xffff, 0, 0 },
2381 {
2382 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2383 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
2384 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2385 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2386 { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ * 8 },
2387 },
2388 },
2389
2390 /* SIIG Cyber 4S PCI 16C650 (10x family): 4S */
2391 { "SIIG Cyber 4S PCI 16C650 (10x family)",
2392 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_4S650, 0, 0 },
2393 { 0xffff, 0xffff, 0, 0 },
2394 {
2395 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2396 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
2397 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2398 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2399 { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ * 8 },
2400 },
2401 },
2402
2403 /* SIIG Cyber 4S PCI 16C850 (10x family): 4S */
2404 { "SIIG Cyber 4S PCI 16C850 (10x family)",
2405 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER10_4S850, 0, 0 },
2406 { 0xffff, 0xffff, 0, 0 },
2407 {
2408 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00,
2409 (COM_FREQ * 8)|PUC_COM_SIIG10x|PUC_PORT_USR0 },
2410 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2411 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2412 { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ * 8 },
2413 },
2414 },
2415
2416 /*
2417 * SIIG "20x" family boards.
2418 */
2419
2420 /* SIIG Cyber Serial PCI 16C550 (20x family): 1S */
2421 { "SIIG Cyber Serial PCI 16C550 (20x family)",
2422 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_S550, 0, 0 },
2423 { 0xffff, 0xffff, 0, 0 },
2424 {
2425 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2426 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2427 },
2428 },
2429
2430 /* SIIG Cyber Serial PCI 16C650 (20x family): 1S */
2431 { "SIIG Cyber Serial PCI 16C650 (20x family)",
2432 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_S650, 0, 0 },
2433 { 0xffff, 0xffff, 0, 0 },
2434 {
2435 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2436 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2437 },
2438 },
2439
2440 /* SIIG Cyber Serial PCI 16C850 (20x family): 1S */
2441 { "SIIG Cyber Serial PCI 16C850 (20x family)",
2442 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_S850, 0, 0 },
2443 { 0xffff, 0xffff, 0, 0 },
2444 {
2445 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2446 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2447 },
2448 },
2449
2450 /* SIIG Cyber I/O PCI 16C550 (20x family): 1S, 1P */
2451 { "SIIG Cyber I/O PCI 16C550 (20x family)",
2452 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_IO550, 0, 0 },
2453 { 0xffff, 0xffff, 0, 0 },
2454 {
2455 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2456 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2457 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2458 },
2459 },
2460
2461 /* SIIG Cyber I/O PCI 16C650 (20x family): 1S, 1P */
2462 { "SIIG Cyber I/O PCI 16C650 (20x family)",
2463 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_IO650, 0, 0 },
2464 { 0xffff, 0xffff, 0, 0 },
2465 {
2466 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2467 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2468 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2469 },
2470 },
2471
2472 /* SIIG Cyber I/O PCI 16C850 (20x family): 1S, 1P */
2473 { "SIIG Cyber I/O PCI 16C850 (20x family)",
2474 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_IO850, 0, 0 },
2475 { 0xffff, 0xffff, 0, 0 },
2476 {
2477 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2478 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2479 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2480 },
2481 },
2482
2483 /* SIIG Cyber Parallel PCI (20x family): 1P */
2484 { "SIIG Cyber Parallel PCI (20x family)",
2485 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_P, 0, 0 },
2486 { 0xffff, 0xffff, 0, 0 },
2487 {
2488 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
2489 },
2490 },
2491
2492 /* SIIG Cyber Parallel Dual PCI (20x family): 2P */
2493 { "SIIG Cyber Parallel Dual PCI (20x family)",
2494 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2P, 0, 0 },
2495 { 0xffff, 0xffff, 0, 0 },
2496 {
2497 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
2498 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2499 },
2500 },
2501
2502 /* SIIG Cyber Serial Dual PCI 16C550 (20x family): 2S */
2503 { "SIIG Cyber Serial Dual PCI 16C550 (20x family)",
2504 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2S550, 0, 0 },
2505 { 0xffff, 0xffff, 0, 0 },
2506 {
2507 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2508 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2509 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
2510 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
2511 },
2512 },
2513
2514 /* SIIG Cyber Serial Dual PCI 16C650 (20x family): 2S */
2515 { "SIIG Cyber Serial Dual PCI 16C650 (20x family)",
2516 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2S650, 0, 0 },
2517 { 0xffff, 0xffff, 0, 0 },
2518 {
2519 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2520 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2521 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
2522 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
2523 },
2524 },
2525
2526 /* SIIG Cyber Serial Dual PCI 16C850 (20x family): 2S */
2527 { "SIIG Cyber Serial Dual PCI 16C850 (20x family)",
2528 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2S850, 0, 0 },
2529 { 0xffff, 0xffff, 0, 0 },
2530 {
2531 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2532 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2533 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
2534 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
2535 },
2536 },
2537
2538 /* SIIG Cyber 2P1S PCI 16C550 (20x family): 1S, 2P */
2539 { "SIIG Cyber 2P1S PCI 16C550 (20x family)",
2540 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2P1S550,
2541 0, 0 },
2542 { 0xffff, 0xffff, 0, 0 },
2543 {
2544 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2545 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2546 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2547 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2548 },
2549 },
2550
2551 /* SIIG Cyber 2P1S PCI 16C650 (20x family): 1S, 2P */
2552 { "SIIG Cyber 2P1S PCI 16C650 (20x family)",
2553 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2P1S650,
2554 0, 0 },
2555 { 0xffff, 0xffff, 0, 0 },
2556 {
2557 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2558 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2559 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2560 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2561 },
2562 },
2563
2564 /* SIIG Cyber 2P1S PCI 16C850 (20x family): 1S, 2P */
2565 { "SIIG Cyber 2P1S PCI 16C850 (20x family)",
2566 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2P1S850,
2567 0, 0 },
2568 { 0xffff, 0xffff, 0, 0 },
2569 {
2570 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2571 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2572 { PUC_PORT_TYPE_LPT, PCI_BAR1, 0x00, 0x00 },
2573 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2574 },
2575 },
2576
2577 /* SIIG Cyber 4S PCI 16C550 (20x family): 4S */
2578 { "SIIG Cyber 4S PCI 16C550 (20x family)",
2579 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_4S550, 0, 0 },
2580 { 0xffff, 0xffff, 0, 0 },
2581 {
2582 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2583 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2584 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2585 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2586 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2587 },
2588 },
2589
2590 /* SIIG Cyber 4S PCI 16C650 (20x family): 4S */
2591 { "SIIG Cyber 4S PCI 16C650 (20x family)",
2592 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_4S650, 0, 0 },
2593 { 0xffff, 0xffff, 0, 0 },
2594 {
2595 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2596 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2597 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2598 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2599 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2600 },
2601 },
2602
2603 /* SIIG Cyber 4S PCI 16C850 (20x family): 4S */
2604 { "SIIG Cyber 4S PCI 16C850 (20x family)",
2605 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_4S850, 0, 0 },
2606 { 0xffff, 0xffff, 0, 0 },
2607 {
2608 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2609 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2610 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2611 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2612 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2613 },
2614 },
2615
2616 /* SIIG Cyber 2S1P PCI 16C550 (20x family): 2S, 1P */
2617 { "SIIG Cyber 2S1P PCI 16C550 (20x family)",
2618 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2S1P550,
2619 0, 0 },
2620 { 0xffff, 0xffff, 0, 0 },
2621 {
2622 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2623 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2624 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
2625 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
2626 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2627 },
2628 },
2629
2630 /* SIIG Cyber 2S1P PCI 16C650 (20x family): 2S, 1P */
2631 { "SIIG Cyber 2S1P PCI 16C650 (20x family)",
2632 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2S1P650,
2633 0, 0 },
2634 { 0xffff, 0xffff, 0, 0 },
2635 {
2636 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2637 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2638 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
2639 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
2640 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2641 },
2642 },
2643
2644 /* SIIG Cyber 2S1P PCI 16C850 (20x family): 2S, 1P */
2645 { "SIIG Cyber 2S1P PCI 16C850 (20x family)",
2646 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_CYBER20_2S1P850,
2647 0, 0 },
2648 { 0xffff, 0xffff, 0, 0 },
2649 {
2650 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2651 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2652 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00,
2653 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR1 },
2654 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2655 },
2656 },
2657
2658 /* SIIG PS8000 PCI 8S 16C550 (20x family): 8S - 16 Byte FIFOs */
2659 { "SIIG PS8000 PCI 8S 16C550 (20x family)",
2660 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_PS8000P550, 0, 0 },
2661 { 0xffff, 0xffff, 0, 0 },
2662 {
2663 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2664 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2665 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2666 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2667 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2668 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2669 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
2670 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
2671 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
2672 },
2673 },
2674
2675 /* SIIG PS8000 PCI 8S 16C650 (20x family): 8S - 32 Byte FIFOs */
2676 { "SIIG PS8000 PCI 8S 16C650 (20x family)",
2677 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_PS8000P650, 0, 0 },
2678 { 0xffff, 0xffff, 0, 0 },
2679 {
2680 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2681 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2682 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2683 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2684 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2685 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2686 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
2687 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
2688 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
2689 },
2690 },
2691
2692 /* SIIG PS8000 PCI 8S 16C850 (20x family): 8S - 128 Byte FIFOs */
2693 { "SIIG PS8000 PCI 8S 16C850 (20x family)",
2694 { PCI_VENDOR_SIIG, PCI_PRODUCT_SIIG_PS8000P850, 0, 0 },
2695 { 0xffff, 0xffff, 0, 0 },
2696 {
2697 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00,
2698 (COM_FREQ * 8)|PUC_COM_SIIG20x|PUC_PORT_USR0 },
2699 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2700 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2701 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ * 8 },
2702 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2703 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
2704 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
2705 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
2706 },
2707 },
2708
2709 /*
2710 * SUNIX 40XX series of serial/parallel combo cards.
2711 * Tested with 4055A and 4065A.
2712 */
2713 { "SUNIX 400X 1P",
2714 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2715 PCI_VENDOR_SUNIX, 0x4000 },
2716 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2717 {
2718 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
2719 },
2720 },
2721
2722 { "SUNIX 401X 2P",
2723 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2724 PCI_VENDOR_SUNIX, 0x4010 },
2725 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2726 {
2727 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
2728 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2729 },
2730 },
2731
2732 { "SUNIX 402X 1S",
2733 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2734 PCI_VENDOR_SUNIX, 0x4020 },
2735 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2736 {
2737 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2738 },
2739 },
2740
2741 { "SUNIX 403X 2S",
2742 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2743 PCI_VENDOR_SUNIX, 0x4030 },
2744 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2745 {
2746 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2747 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2748 },
2749 },
2750
2751 { "SUNIX 4036 2S",
2752 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2753 PCI_VENDOR_SUNIX, 0x0002 },
2754 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2755 {
2756 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2757 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2758 },
2759 },
2760
2761 { "SUNIX 405X 4S",
2762 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2763 PCI_VENDOR_SUNIX, 0x4050 },
2764 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2765 {
2766 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2767 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2768 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ},
2769 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ},
2770 },
2771 },
2772
2773 { "SUNIX 406X 8S",
2774 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2775 PCI_VENDOR_SUNIX, 0x4060 },
2776 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2777 {
2778 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2779 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2780 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ},
2781 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ},
2782 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ},
2783 { PUC_PORT_TYPE_COM, PCI_BAR3, 0x00, COM_FREQ},
2784 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ},
2785 { PUC_PORT_TYPE_COM, PCI_BAR5, 0x00, COM_FREQ},
2786 },
2787 },
2788
2789 { "SUNIX 407X 2S/1P",
2790 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2791 PCI_VENDOR_SUNIX, 0x4070 },
2792 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2793 {
2794 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2795 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2796 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2797 },
2798 },
2799
2800 { "SUNIX 408X 2S/2P",
2801 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2802 PCI_VENDOR_SUNIX, 0x4080 },
2803 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2804 {
2805 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2806 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2807 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2808 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2809 },
2810 },
2811
2812 { "SUNIX 409X 4S/2P",
2813 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2814 PCI_VENDOR_SUNIX, 0x4090 },
2815 { 0xffff, 0xffff, 0xffff, 0xeff0 },
2816 {
2817 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2818 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2819 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ},
2820 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x08, COM_FREQ},
2821 { PUC_PORT_TYPE_LPT, PCI_BAR2, 0x00, 0x00 },
2822 { PUC_PORT_TYPE_LPT, PCI_BAR4, 0x00, 0x00 },
2823 },
2824 },
2825
2826 /*
2827 * Dolphin Peripherals 4036 (dual serial port) card.
2828 * (Dolpin 4025 has the same ID but only one port)
2829 */
2830 { "Dolphin Peripherals 4036",
2831 { PCI_VENDOR_SUNIX, PCI_PRODUCT_SUNIX_PCI2S550,
2832 0x0, 0x0 },
2833 { 0xffff, 0xffff, 0x0, 0x0 },
2834 {
2835 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2836 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2837 },
2838 },
2839
2840 /*
2841 * XXX no entry because I have no data:
2842 * XXX Dolphin Peripherals 4078 (dual serial and single parallel)
2843 */
2844
2845 /* SD-LAB PCI I/O Card 4S */
2846 { "Syba Tech Ltd. PCI-4S",
2847 { PCI_VENDOR_SYBA, PCI_PRODUCT_SYBA_4S, 0, 0 },
2848 { 0xffff, 0xffff, 0, 0 },
2849 {
2850 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x3e8, COM_FREQ },
2851 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x2e8, COM_FREQ },
2852 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x3f8, COM_FREQ },
2853 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x2f8, COM_FREQ },
2854 },
2855 },
2856
2857 /* SD-LAB PCI I/O Card 4S2P */
2858 { "Syba Tech Ltd. PCI-4S2P-550-ECP",
2859 { PCI_VENDOR_SYBA, PCI_PRODUCT_SYBA_4S2P, 0, 0 },
2860 { 0xffff, 0xffff, 0, 0 },
2861 {
2862 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x2e8, COM_FREQ },
2863 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x2f8, COM_FREQ },
2864 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x000, 0x00 },
2865 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x3e8, COM_FREQ },
2866 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x3f8, COM_FREQ },
2867 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x000, 0x00 },
2868 },
2869 },
2870
2871 /* SystemBase SB16C1050 UARTs */
2872 { "SystemBase SB16C1050",
2873 { PCI_VENDOR_SYSTEMBASE, PCI_PRODUCT_SYSTEMBASE_SB16C1050, 0, 0 },
2874 { 0xffff, 0xffff, 0, 0 },
2875 {
2876 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8},
2877 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8},
2878 },
2879 },
2880
2881 /* SystemBase SB16C1054 UARTs */
2882 { "SystemBase SB16C1054",
2883 { PCI_VENDOR_SYSTEMBASE, PCI_PRODUCT_SYSTEMBASE_SB16C1054, 0, 0 },
2884 { 0xffff, 0xffff, 0, 0 },
2885 {
2886 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2887 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
2888 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ },
2889 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ },
2890 },
2891 },
2892
2893 /* SystemBase SB16C1058 UARTs */
2894 { "SystemBase SB16C1058",
2895 { PCI_VENDOR_SYSTEMBASE, PCI_PRODUCT_SYSTEMBASE_SB16C1058, 0, 0 },
2896 { 0xffff, 0xffff, 0, 0 },
2897 {
2898 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
2899 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ },
2900 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ },
2901 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ },
2902 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x20, COM_FREQ },
2903 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x28, COM_FREQ },
2904 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x30, COM_FREQ },
2905 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x38, COM_FREQ },
2906 },
2907 },
2908
2909 /*
2910 * VScom PCI 010L
2911 * one lpt
2912 * untested
2913 */
2914 { "VScom PCI-010L",
2915 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI010L, 0, 0 },
2916 { 0xffff, 0xffff, 0, 0 },
2917 {
2918 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2919 },
2920 },
2921
2922 /*
2923 * VScom PCI 100L
2924 * one com
2925 * The one I have defaults to a fequency of 14.7456 MHz which is
2926 * jumper J1 set to 2-3.
2927 */
2928 { "VScom PCI-100L",
2929 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI100L, 0, 0 },
2930 { 0xffff, 0xffff, 0, 0 },
2931 {
2932 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2933 },
2934 },
2935
2936 /*
2937 * VScom PCI 110L
2938 * one com, one lpt
2939 * untested
2940 */
2941 { "VScom PCI-110L",
2942 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI110L, 0, 0 },
2943 { 0xffff, 0xffff, 0, 0 },
2944 {
2945 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2946 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2947 },
2948 },
2949
2950 /*
2951 * VScom PCI-200L has 2 x 16550 UARTS.
2952 * The board has a jumper which allows you to select a clock speed
2953 * of either 14.7456MHz or 1.8432MHz. By default it runs at
2954 * the fast speed.
2955 */
2956 { "VScom PCI-200L with 2 x 16550 UARTS",
2957 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200L, 0, 0 },
2958 { 0xffff, 0xffff, 0, 0 },
2959 {
2960 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2961 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2962 },
2963 },
2964
2965 /*
2966 * VScom PCI-210L
2967 * Has a jumper for frequency selection, defaults to 8x as used here
2968 * two com, one lpt
2969 */
2970 { "VScom PCI-210L",
2971 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI210L, 0, 0 },
2972 { 0xffff, 0xffff, 0, 0 },
2973 {
2974 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2975 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2976 { PUC_PORT_TYPE_LPT, PCI_BAR3, 0x00, 0x00 },
2977 },
2978 },
2979
2980 /* VScom PCI-200Li */
2981 { "VScom PCI-200Li",
2982 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200LI, 0, 0 },
2983 { 0xffff, 0xffff, 0, 0 },
2984 {
2985 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ },
2986 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ },
2987 },
2988 },
2989
2990 /* PCI-400L: VendorID is reported to be 0x10d2 instead of 0x14d2. */
2991 { "VScom PCI-400L",
2992 { PCI_VENDOR_MOLEX, PCI_PRODUCT_MOLEX_VSCOM_PCI400L, 0, 0 },
2993 { 0xffff, 0xffff, 0, 0 },
2994 {
2995 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
2996 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
2997 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
2998 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
2999 },
3000 },
3001
3002 { "VScom PCI-800L",
3003 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI800L, 0, 0 },
3004 { 0xffff, 0xffff, 0, 0 },
3005 {
3006 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3007 { PUC_PORT_TYPE_COM, PCI_BAR2, 0x00, COM_FREQ * 8 },
3008 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x00, COM_FREQ * 8 },
3009 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x08, COM_FREQ * 8 },
3010 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x10, COM_FREQ * 8 },
3011 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x18, COM_FREQ * 8 },
3012 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x20, COM_FREQ * 8 },
3013 { PUC_PORT_TYPE_COM, PCI_BAR4, 0x28, COM_FREQ * 8 },
3014 },
3015 },
3016
3017 { "VScom PCI-011H",
3018 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI011H, 0, 0 },
3019 { 0xffff, 0xffff, 0, 0 },
3020 {
3021 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3022 },
3023 },
3024
3025 /*
3026 * VScom PCI x10H, 1 lpt.
3027 * is the lpt part of VScom 110H, 210H, 410H
3028 */
3029 { "VScom PCI-x10H",
3030 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCIx10H, 0, 0 },
3031 { 0xffff, 0xffff, 0, 0 },
3032 {
3033 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3034 },
3035 },
3036
3037 /*
3038 * VScom PCI 100H, little sister of 800H, 1 com.
3039 * also com part of VScom 110H
3040 * The one I have defaults to a fequency of 14.7456 MHz which is
3041 * jumper J1 set to 2-3.
3042 */
3043 { "VScom PCI-100H",
3044 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI100H, 0, 0 },
3045 { 0xffff, 0xffff, 0, 0 },
3046 {
3047 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3048 },
3049 },
3050
3051 /*
3052 * VScom PCI-800H. Uses 8 16950 UART, behind a PCI chips that offers
3053 * 4 com port on PCI device 0 and 4 on PCI device 1. PCI device 0 has
3054 * device ID 3 and PCI device 1 device ID 4.
3055 */
3056 { "VScom PCI-800H",
3057 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI800H, 0, 0 },
3058 { 0xffff, 0xffff, 0, 0 },
3059 {
3060 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3061 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3062 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
3063 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
3064 },
3065 },
3066 { "VScom PCI-800H",
3067 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI800H_1, 0, 0 },
3068 { 0xffff, 0xffff, 0, 0 },
3069 {
3070 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3071 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3072 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x10, COM_FREQ * 8 },
3073 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x18, COM_FREQ * 8 },
3074 },
3075 },
3076 { "VScom PCI-200H",
3077 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200H, 0, 0 },
3078 { 0xffff, 0xffff, 0, 0 },
3079 {
3080 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3081 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x08, COM_FREQ * 8 },
3082 },
3083 },
3084
3085 { "VScom PCI-010HV2",
3086 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI010HV2, 0, 0 },
3087 { 0xffff, 0xffff, 0, 0 },
3088 {
3089 { PUC_PORT_TYPE_LPT, PCI_BAR0, 0x00, 0x00 },
3090 },
3091 },
3092 { "VScom PCI-200HV2",
3093 { PCI_VENDOR_TITAN, PCI_PRODUCT_TITAN_VSCOM_PCI200HV2, 0, 0 },
3094 { 0xffff, 0xffff, 0, 0 },
3095 {
3096 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ * 8 },
3097 { PUC_PORT_TYPE_COM, PCI_BAR1, 0x00, COM_FREQ * 8 },
3098 },
3099 },
3100
3101 /* US Robotics (3Com) PCI Modems */
3102 { "US Robotics (3Com) 3CP5609 PCI 16550 Modem",
3103 { PCI_VENDOR_USR, PCI_PRODUCT_USR_3CP5609, 0, 0 },
3104 { 0xffff, 0xffff, 0, 0 },
3105 {
3106 { PUC_PORT_TYPE_COM, PCI_BAR0, 0x00, COM_FREQ },
3107 },
3108 },
3109
3110 { .name = NULL },
3111 };
3112