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