File: | dev/usb/uftdi.c |
Warning: | line 1077, column 13 The left operand of '&' is a garbage value |
Press '?' to see keyboard shortcuts
Keyboard shortcuts:
1 | /* $OpenBSD: uftdi.c,v 1.76 2020/02/22 14:01:34 jasper Exp $ */ | |||
2 | /* $NetBSD: uftdi.c,v 1.14 2003/02/23 04:20:07 simonb Exp $ */ | |||
3 | ||||
4 | /* | |||
5 | * Copyright (c) 2000 The NetBSD Foundation, Inc. | |||
6 | * All rights reserved. | |||
7 | * | |||
8 | * This code is derived from software contributed to The NetBSD Foundation | |||
9 | * by Lennart Augustsson (lennart@augustsson.net). | |||
10 | * | |||
11 | * Redistribution and use in source and binary forms, with or without | |||
12 | * modification, are permitted provided that the following conditions | |||
13 | * are met: | |||
14 | * 1. Redistributions of source code must retain the above copyright | |||
15 | * notice, this list of conditions and the following disclaimer. | |||
16 | * 2. Redistributions in binary form must reproduce the above copyright | |||
17 | * notice, this list of conditions and the following disclaimer in the | |||
18 | * documentation and/or other materials provided with the distribution. | |||
19 | * | |||
20 | * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS | |||
21 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED | |||
22 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | |||
23 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS | |||
24 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | |||
25 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | |||
26 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | |||
27 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | |||
28 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | |||
29 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |||
30 | * POSSIBILITY OF SUCH DAMAGE. | |||
31 | */ | |||
32 | ||||
33 | /* | |||
34 | * FTDI FT8U100AX serial adapter driver | |||
35 | */ | |||
36 | ||||
37 | /* | |||
38 | * XXX This driver will not support multiple serial ports. | |||
39 | * XXX The ucom layer needs to be extended first. | |||
40 | */ | |||
41 | ||||
42 | #include <sys/param.h> | |||
43 | #include <sys/systm.h> | |||
44 | #include <sys/kernel.h> | |||
45 | #include <sys/device.h> | |||
46 | #include <sys/conf.h> | |||
47 | #include <sys/tty.h> | |||
48 | ||||
49 | #include <dev/usb/usb.h> | |||
50 | ||||
51 | #include <dev/usb/usbdi.h> | |||
52 | #include <dev/usb/usbdi_util.h> | |||
53 | #include <dev/usb/usbdevs.h> | |||
54 | ||||
55 | #include <dev/usb/ucomvar.h> | |||
56 | ||||
57 | #include <dev/usb/uftdireg.h> | |||
58 | ||||
59 | #ifdef UFTDI_DEBUG | |||
60 | #define DPRINTF(x) do { if (uftdidebug) printf x; } while (0) | |||
61 | #define DPRINTFN(n,x) do { if (uftdidebug>(n)) printf x; } while (0) | |||
62 | int uftdidebug = 0; | |||
63 | #else | |||
64 | #define DPRINTF(x) | |||
65 | #define DPRINTFN(n,x) | |||
66 | #endif | |||
67 | ||||
68 | /* | |||
69 | * These are the maximum number of bytes transferred per frame. | |||
70 | * The output buffer size cannot be increased due to the size encoding. | |||
71 | */ | |||
72 | #define UFTDIIBUFSIZE64 64 | |||
73 | #define UFTDIOBUFSIZE64 64 | |||
74 | ||||
75 | struct uftdi_softc { | |||
76 | struct device sc_dev; /* base device */ | |||
77 | struct usbd_device *sc_udev; /* device */ | |||
78 | struct usbd_interface *sc_iface; /* interface */ | |||
79 | ||||
80 | enum uftdi_type sc_type; | |||
81 | u_int sc_hdrlen; | |||
82 | ||||
83 | u_char sc_msr; | |||
84 | u_char sc_lsr; | |||
85 | ||||
86 | struct device *sc_subdev; | |||
87 | ||||
88 | u_int last_lcr; | |||
89 | }; | |||
90 | ||||
91 | void uftdi_get_status(void *, int portno, u_char *lsr, u_char *msr); | |||
92 | void uftdi_set(void *, int, int, int); | |||
93 | int uftdi_param(void *, int, struct termios *); | |||
94 | int uftdi_open(void *sc, int portno); | |||
95 | void uftdi_read(void *sc, int portno, u_char **ptr, | |||
96 | u_int32_t *count); | |||
97 | void uftdi_write(void *sc, int portno, u_char *to, u_char *from, | |||
98 | u_int32_t *count); | |||
99 | void uftdi_break(void *sc, int portno, int onoff); | |||
100 | int uftdi_8u232am_getrate(speed_t speed, int *rate); | |||
101 | int uftdi_2232h_getrate(speed_t speed, int *rate); | |||
102 | ||||
103 | struct ucom_methods uftdi_methods = { | |||
104 | uftdi_get_status, | |||
105 | uftdi_set, | |||
106 | uftdi_param, | |||
107 | NULL((void *)0), | |||
108 | uftdi_open, | |||
109 | NULL((void *)0), | |||
110 | uftdi_read, | |||
111 | uftdi_write, | |||
112 | }; | |||
113 | ||||
114 | int uftdi_match(struct device *, void *, void *); | |||
115 | void uftdi_attach(struct device *, struct device *, void *); | |||
116 | int uftdi_detach(struct device *, int); | |||
117 | ||||
118 | struct cfdriver uftdi_cd = { | |||
119 | NULL((void *)0), "uftdi", DV_DULL | |||
120 | }; | |||
121 | ||||
122 | const struct cfattach uftdi_ca = { | |||
123 | sizeof(struct uftdi_softc), uftdi_match, uftdi_attach, uftdi_detach | |||
124 | }; | |||
125 | ||||
126 | static const struct usb_devno uftdi_devs[] = { | |||
127 | { USB_VENDOR_ALTI20x1bc9, USB_PRODUCT_ALTI2_NEPTUNE30x6001 }, | |||
128 | { USB_VENDOR_ANALOGDEVICES0x0456, USB_PRODUCT_ANALOGDEVICES_GNICE0xf000 }, | |||
129 | { USB_VENDOR_ANALOGDEVICES0x0456, USB_PRODUCT_ANALOGDEVICES_GNICEPLUS0xf001 }, | |||
130 | { USB_VENDOR_ATMEL0x03eb, USB_PRODUCT_ATMEL_STK5410x2109 }, | |||
131 | { USB_VENDOR_BAYER0x1a79, USB_PRODUCT_BAYER_CONTOUR0x6001 }, | |||
132 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_232USB9M0xac27 }, | |||
133 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_485USB9F2W0xac25 }, | |||
134 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_485USB9F4W0xac26 }, | |||
135 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_485USBTB_2W0xac33 }, | |||
136 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_485USBTB_4W0xac34 }, | |||
137 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_TTL3USB9M0xac50 }, | |||
138 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_TTL5USB9M0xac49 }, | |||
139 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USO9ML20xac03 }, | |||
140 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USO9ML2DR0xac17 }, | |||
141 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USO9ML2DR20xac16 }, | |||
142 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USOPTL40xac11 }, | |||
143 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USOPTL4DR0xac19 }, | |||
144 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USOPTL4DR20xac18 }, | |||
145 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USOTL40xac01 }, | |||
146 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USPTL40xac12 }, | |||
147 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_USTL40xac02 }, | |||
148 | { USB_VENDOR_BBELECTR0x0856, USB_PRODUCT_BBELECTR_ZZ_PROG10xba02 }, | |||
149 | { USB_VENDOR_DRESDENELEC0x1cf1, USB_PRODUCT_DRESDENELEC_STB0x0001 }, | |||
150 | { USB_VENDOR_DRESDENELEC0x1cf1, USB_PRODUCT_DRESDENELEC_WHT0x0004 }, | |||
151 | { USB_VENDOR_ELEKTOR0x0c7d, USB_PRODUCT_ELEKTOR_FT323R0x0005 }, | |||
152 | { USB_VENDOR_EVOLUTION0xdeee, USB_PRODUCT_EVOLUTION_ER10x0300 }, | |||
153 | { USB_VENDOR_EVOLUTION0xdeee, USB_PRODUCT_EVOLUTION_RCM4_10x0302 }, | |||
154 | { USB_VENDOR_EVOLUTION0xdeee, USB_PRODUCT_EVOLUTION_RCM4_20x0303 }, | |||
155 | { USB_VENDOR_FALCOM0x0f94, USB_PRODUCT_FALCOM_SAMBA0x0005 }, | |||
156 | { USB_VENDOR_FALCOM0x0f94, USB_PRODUCT_FALCOM_TWIST0x0001 }, | |||
157 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ACCESSO0xfad0 }, | |||
158 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ACG_HFDUAL0xdd20 }, | |||
159 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ACTROBOTS0xe548 }, | |||
160 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ACTZWAVE0xf2d0 }, | |||
161 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_AMC2320xff00 }, | |||
162 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ARTEMIS0xdf28 }, | |||
163 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_10xc990 }, | |||
164 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_20xc991 }, | |||
165 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_30xc992 }, | |||
166 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_40xc993 }, | |||
167 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_50xc994 }, | |||
168 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_60xc995 }, | |||
169 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_70xc996 }, | |||
170 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ASK_RDR4X7_80xc997 }, | |||
171 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ATK160xdf30 }, | |||
172 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ATK16C0xdf32 }, | |||
173 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ATK16HR0xdf31 }, | |||
174 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ATK16HRC0xdf33 }, | |||
175 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ATK16IC0xdf35 }, | |||
176 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_BCS_SE9230xfb99 }, | |||
177 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CANDAPTER0x9f80 }, | |||
178 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CANUSB0xffa8 }, | |||
179 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CCS_ICDU200xf9d0 }, | |||
180 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CCS_ICDU400xf9d1 }, | |||
181 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CCS_ICDU640xf9d4 }, | |||
182 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CCS_LOAD_N_GO0xf9d3 }, | |||
183 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CCS_MACHX0xf9d2 }, | |||
184 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CCS_PRIME80xf9d5 }, | |||
185 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_CHAMELEON0xcaa0 }, | |||
186 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_COASTAL_TNCX0xf448 }, | |||
187 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_DGQG0xef50 }, | |||
188 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_DMX4ALL0xc850 }, | |||
189 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_DUSB0xef51 }, | |||
190 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ECLO_1WIRE0xea90 }, | |||
191 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ECO_PRO0xe520 }, | |||
192 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_EISCOU0xe888 }, | |||
193 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_ALC85000xf06e }, | |||
194 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_CLI70000xfb59 }, | |||
195 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_CSI80xe0f0 }, | |||
196 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_EM1000DL0xe0f1 }, | |||
197 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_EM1010PC0xe0ef }, | |||
198 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_FEM0xe00a }, | |||
199 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_FHZ1000PC0xf06f }, | |||
200 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_FHZ1300PC0xe0e8 }, | |||
201 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_FM3RX0xe0ed }, | |||
202 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_FS20SIG0xe0f4 }, | |||
203 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_HS4850xe0ea }, | |||
204 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_KL1000xe002 }, | |||
205 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_MSM10xe001 }, | |||
206 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_PCD2000xf06c }, | |||
207 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_PCK1000xe0f2 }, | |||
208 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_PPS73300xfb5c }, | |||
209 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_RFP5000xe0f3 }, | |||
210 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_T11000xf06b }, | |||
211 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_TFD1280xe0ec }, | |||
212 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_TFM1000xfb5d }, | |||
213 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_TWS5500xe009 }, | |||
214 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UAD70xf069 }, | |||
215 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UAD80xf068 }, | |||
216 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UDF770xfb5e }, | |||
217 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UIO880xfb5f }, | |||
218 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_ULA2000xf06d }, | |||
219 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UM1000xfb5a }, | |||
220 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UMS1000xe0eb }, | |||
221 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UO1000xfb5b }, | |||
222 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UR1000xfb58 }, | |||
223 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_USI20xf06a }, | |||
224 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_USR0xe000 }, | |||
225 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_UTP80xe0f5 }, | |||
226 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_WS300PC0xe0f6 }, | |||
227 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_WS444PC0xe0f7 }, | |||
228 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_WS5000xe0e9 }, | |||
229 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_WS5500xe004 }, | |||
230 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_WS7770xe0ee }, | |||
231 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_ELV_WS8880xe008 }, | |||
232 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FISCO0xe40b }, | |||
233 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT232RL0xfbfa }, | |||
234 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT232_10x0232 }, | |||
235 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT232_30x6006 }, | |||
236 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT232_40x6007 }, | |||
237 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT232_50x6008 }, | |||
238 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT232_60x6009 }, | |||
239 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FT4232H0x6011 }, | |||
240 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_FTX0x6015 }, | |||
241 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GAMMASCOUT0xd678 }, | |||
242 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_10xe808 }, | |||
243 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_20xe809 }, | |||
244 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_30xe80a }, | |||
245 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_40xe80b }, | |||
246 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_50xe80c }, | |||
247 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_60xe80d }, | |||
248 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_70xe80e }, | |||
249 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_80xe80f }, | |||
250 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_90xe88d }, | |||
251 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_A0xe88e }, | |||
252 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_GUDE_B0xe88f }, | |||
253 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_HO8200xed74 }, | |||
254 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_HO8700xed71 }, | |||
255 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_10xff3f }, | |||
256 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_APP700xff3d }, | |||
257 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_PCMCIA0xff3a }, | |||
258 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_PEDO0xff3e }, | |||
259 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_PICPRO0xff39 }, | |||
260 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_PK10xff3b }, | |||
261 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_RS232MON0xff3c }, | |||
262 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IBS_US4850xff38 }, | |||
263 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IPLUS0xd070 }, | |||
264 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_IPLUS20xd071 }, | |||
265 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_JTAGCABLEII0xd738 }, | |||
266 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_5470xfc0a }, | |||
267 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6310xfc0c }, | |||
268 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6320xfc08 }, | |||
269 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6330xfc0b }, | |||
270 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6340xfc09 }, | |||
271 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6350xfc0d }, | |||
272 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6400xfc0e }, | |||
273 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_CFA_6420xfc0f }, | |||
274 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_LK202_240xfa03 }, | |||
275 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_LK204_240xfa04 }, | |||
276 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_MTXO0xfa02 }, | |||
277 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LCD_MX2000xfa01 }, | |||
278 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LINX_10xf44a }, | |||
279 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LINX_20xf44b }, | |||
280 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LINX_30xf44c }, | |||
281 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LINX_MASTER20xf449 }, | |||
282 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LM3S_DEVEL0xbcd8 }, | |||
283 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LM3S_EVAL0xbcd9 }, | |||
284 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_LOCOBUFFER0xc7d0 }, | |||
285 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MATRIX_20xfa05 }, | |||
286 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MATRIX_30xfa06 }, | |||
287 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_DB90xeeed }, | |||
288 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_IC0xeeec }, | |||
289 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_KW0xeee8 }, | |||
290 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_RS2320xeeee }, | |||
291 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_Y60xeeea }, | |||
292 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_Y80xeeeb }, | |||
293 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_Y90xeeef }, | |||
294 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MHAM_YS0xeee9 }, | |||
295 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MJS_SIRIUS_PC_10xca81 }, | |||
296 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_MJS_SIRIUS_PC_20x9379 }, | |||
297 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_NXTCAM0xabb8 }, | |||
298 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OCEANIC0xf460 }, | |||
299 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OOCDLINK0xbaf8 }, | |||
300 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENDCC0xbfd8 }, | |||
301 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENDCC_GATEWAY0xbfdb }, | |||
302 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENDCC_SNIFFER0xbfd9 }, | |||
303 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENDCC_THROTTLE0xbfda }, | |||
304 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENPORT_13M0xcc48 }, | |||
305 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENPORT_13S0xcc49 }, | |||
306 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENPORT_13U0xcc4a }, | |||
307 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_OPENRD0x9e90 }, | |||
308 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PCDJ_DAC20xfa88 }, | |||
309 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PIEGROUP_IR0xf208 }, | |||
310 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PROTEGO_10xfc70 }, | |||
311 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PROTEGO_30xfc72 }, | |||
312 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PROTEGO_40xfc73 }, | |||
313 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PROTEGO_R2000xfc71 }, | |||
314 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_PYRAMID0xe6c8 }, | |||
315 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_R2000KU_RNG0xfb80 }, | |||
316 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_RELAIS0xfa10 }, | |||
317 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_REU_TINY0xed22 }, | |||
318 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_00xd010 }, | |||
319 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_10xd011 }, | |||
320 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_20xd012 }, | |||
321 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_30xd013 }, | |||
322 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_40xd014 }, | |||
323 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_50xd015 }, | |||
324 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_60xd016 }, | |||
325 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SCS_70xd017 }, | |||
326 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SEMC_DSS200xfc82 }, | |||
327 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SERIAL_2232C0x6010 }, | |||
328 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SERIAL_2232L0xcff8 }, | |||
329 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SERIAL_232BM0xee18 }, | |||
330 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SERIAL_8U100AX0x8372 }, | |||
331 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SERIAL_8U232AM0x6001 }, | |||
332 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SERIAL_8U232AM40x6004 }, | |||
333 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SPROG_II0xf0c8 }, | |||
334 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_SUUNTO0xf680 }, | |||
335 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_TERATRONIK_D2XX0xec89 }, | |||
336 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_TERATRONIK_VCP0xec88 }, | |||
337 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_THORLABS0xfaf0 }, | |||
338 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_TIRA10xfa78 }, | |||
339 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_TNCX0xebe0 }, | |||
340 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_TURTELIZER_JTAG0xbdc8 }, | |||
341 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_UNICOM0xe700 }, | |||
342 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_UOPTBR0xe889 }, | |||
343 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_USBSERIAL0xfa00 }, | |||
344 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_USBUIRT0xf850 }, | |||
345 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_USBX_7070xf857 }, | |||
346 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_VNHC0xfe38 }, | |||
347 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_WESTREX_7770xdc00 }, | |||
348 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_WESTREX_8900F0xdc01 }, | |||
349 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_10xd388 }, | |||
350 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_20xd389 }, | |||
351 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_30xd38a }, | |||
352 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_40xd38b }, | |||
353 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_50xd38c }, | |||
354 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_60xd38d }, | |||
355 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_70xd38e }, | |||
356 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_XSENS_80xd38f }, | |||
357 | { USB_VENDOR_FTDI0x0403, USB_PRODUCT_FTDI_YEI_SC310xe050 }, | |||
358 | { USB_VENDOR_GNOTOMETRICS0x0c33, USB_PRODUCT_GNOTOMETRICS_AURICAL0x0010 }, | |||
359 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_ID10x0004 }, | |||
360 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2000VR0x0013 }, | |||
361 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2000VT0x0012 }, | |||
362 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2C10x0009 }, | |||
363 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2C20x000a }, | |||
364 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2D0x000b }, | |||
365 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2VR0x000d }, | |||
366 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP2VT0x000c }, | |||
367 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP4000VR0x0011 }, | |||
368 | { USB_VENDOR_ICOM0x0c26, USB_PRODUCT_ICOM_RP4000VT0x0010 }, | |||
369 | { USB_VENDOR_IDTECH0x0acd, USB_PRODUCT_IDTECH_SERIAL0x0300 }, | |||
370 | { USB_VENDOR_INTERBIO0x1209, USB_PRODUCT_INTERBIO_IOBOARD0x1002 }, | |||
371 | { USB_VENDOR_INTERBIO0x1209, USB_PRODUCT_INTERBIO_MINIIOBOARD0x1003 }, | |||
372 | { USB_VENDOR_INTERBIO0x1209, USB_PRODUCT_INTERBIO_MINIIOBOARD20x1006 }, | |||
373 | { USB_VENDOR_INTREPIDCS0x093c, USB_PRODUCT_INTREPIDCS_NEOVI0x0701 }, | |||
374 | { USB_VENDOR_INTREPIDCS0x093c, USB_PRODUCT_INTREPIDCS_VALUECAN0x0601 }, | |||
375 | { USB_VENDOR_IODATA0x04bb, USB_PRODUCT_IODATA_FT232R0x093c }, | |||
376 | { USB_VENDOR_JETI0x0c6c, USB_PRODUCT_JETI_SPC12010x04b2 }, | |||
377 | { USB_VENDOR_KOBIL0x0d46, USB_PRODUCT_KOBIL_B10x2020 }, | |||
378 | { USB_VENDOR_KOBIL0x0d46, USB_PRODUCT_KOBIL_KAAN0x2021 }, | |||
379 | { USB_VENDOR_LARSENBRUSGAARD0x0fd8, USB_PRODUCT_LARSENBRUSGAARD_ALTITRACK0x0001 }, | |||
380 | { USB_VENDOR_MARVELL0x9e88, USB_PRODUCT_MARVELL_SHEEVAPLUG0x9e8f }, | |||
381 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01000x0100 }, | |||
382 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01010x0101 }, | |||
383 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01020x0102 }, | |||
384 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01030x0103 }, | |||
385 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01040x0104 }, | |||
386 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01050x0105 }, | |||
387 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01060x0106 }, | |||
388 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01070x0107 }, | |||
389 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01080x0108 }, | |||
390 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01090x0109 }, | |||
391 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_010A0x010a }, | |||
392 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_010B0x010b }, | |||
393 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_010C0x010c }, | |||
394 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_010D0x010d }, | |||
395 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_010E0x010e }, | |||
396 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_010F0x010f }, | |||
397 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01100x0110 }, | |||
398 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01110x0111 }, | |||
399 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01120x0112 }, | |||
400 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01130x0113 }, | |||
401 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01140x0114 }, | |||
402 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01150x0115 }, | |||
403 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01160x0116 }, | |||
404 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01170x0117 }, | |||
405 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01180x0118 }, | |||
406 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01190x0119 }, | |||
407 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_011A0x011a }, | |||
408 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_011B0x011b }, | |||
409 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_011C0x011c }, | |||
410 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_011D0x011d }, | |||
411 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_011E0x011e }, | |||
412 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_011F0x011f }, | |||
413 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01200x0120 }, | |||
414 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01210x0121 }, | |||
415 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01220x0122 }, | |||
416 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01230x0123 }, | |||
417 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01240x0124 }, | |||
418 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01250x0125 }, | |||
419 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01260x0126 }, | |||
420 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01270x0127 }, | |||
421 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01280x0128 }, | |||
422 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01290x0129 }, | |||
423 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_012A0x012a }, | |||
424 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_012B0x012b }, | |||
425 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_012C0x012c }, | |||
426 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_012D0x012d }, | |||
427 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_012E0x012e }, | |||
428 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_012F0x012f }, | |||
429 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01300x0130 }, | |||
430 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01310x0131 }, | |||
431 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01320x0132 }, | |||
432 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01330x0133 }, | |||
433 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01340x0134 }, | |||
434 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01350x0135 }, | |||
435 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01360x0136 }, | |||
436 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01370x0137 }, | |||
437 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01380x0138 }, | |||
438 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01390x0139 }, | |||
439 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_013A0x013a }, | |||
440 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_013B0x013b }, | |||
441 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_013C0x013c }, | |||
442 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_013D0x013d }, | |||
443 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_013E0x013e }, | |||
444 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_013F0x013f }, | |||
445 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01400x0140 }, | |||
446 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01410x0141 }, | |||
447 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01420x0142 }, | |||
448 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01430x0143 }, | |||
449 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01440x0144 }, | |||
450 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01450x0145 }, | |||
451 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01460x0146 }, | |||
452 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01470x0147 }, | |||
453 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01480x0148 }, | |||
454 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01490x0149 }, | |||
455 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_014A0x014a }, | |||
456 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_014B0x014b }, | |||
457 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_014C0x014c }, | |||
458 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_014D0x014d }, | |||
459 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_014E0x014e }, | |||
460 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_014F0x014f }, | |||
461 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01500x0150 }, | |||
462 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01510x0151 }, | |||
463 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01520x0152 }, | |||
464 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01530x0153 }, | |||
465 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01540x0154 }, | |||
466 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01550x0155 }, | |||
467 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01560x0156 }, | |||
468 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01570x0157 }, | |||
469 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01580x0158 }, | |||
470 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01590x0159 }, | |||
471 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_015A0x015a }, | |||
472 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_015B0x015b }, | |||
473 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_015C0x015c }, | |||
474 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_015D0x015d }, | |||
475 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_015E0x015e }, | |||
476 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_015F0x015f }, | |||
477 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01600x0160 }, | |||
478 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01610x0161 }, | |||
479 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01620x0162 }, | |||
480 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01630x0163 }, | |||
481 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01640x0164 }, | |||
482 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01650x0165 }, | |||
483 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01660x0166 }, | |||
484 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01670x0167 }, | |||
485 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01680x0168 }, | |||
486 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01690x0169 }, | |||
487 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_016A0x016a }, | |||
488 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_016B0x016b }, | |||
489 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_016C0x016c }, | |||
490 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_016D0x016d }, | |||
491 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_016E0x016e }, | |||
492 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_016F0x016f }, | |||
493 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01700x0170 }, | |||
494 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01710x0171 }, | |||
495 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01720x0172 }, | |||
496 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01730x0173 }, | |||
497 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01740x0174 }, | |||
498 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01750x0175 }, | |||
499 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01760x0176 }, | |||
500 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01770x0177 }, | |||
501 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01780x0178 }, | |||
502 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01790x0179 }, | |||
503 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_017A0x017a }, | |||
504 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_017B0x017b }, | |||
505 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_017C0x017c }, | |||
506 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_017D0x017d }, | |||
507 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_017E0x017e }, | |||
508 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_017F0x017f }, | |||
509 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01800x0180 }, | |||
510 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01810x0181 }, | |||
511 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01820x0182 }, | |||
512 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01830x0183 }, | |||
513 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01840x0184 }, | |||
514 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01850x0185 }, | |||
515 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01860x0186 }, | |||
516 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01870x0187 }, | |||
517 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01880x0188 }, | |||
518 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01890x0189 }, | |||
519 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_018A0x018a }, | |||
520 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_018B0x018b }, | |||
521 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_018C0x018c }, | |||
522 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_018D0x018d }, | |||
523 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_018E0x018e }, | |||
524 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_018F0x018f }, | |||
525 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01900x0190 }, | |||
526 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01910x0191 }, | |||
527 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01920x0192 }, | |||
528 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01930x0193 }, | |||
529 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01940x0194 }, | |||
530 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01950x0195 }, | |||
531 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01960x0196 }, | |||
532 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01970x0197 }, | |||
533 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01980x0198 }, | |||
534 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01990x0199 }, | |||
535 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_019A0x019a }, | |||
536 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_019B0x019b }, | |||
537 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_019C0x019c }, | |||
538 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_019D0x019d }, | |||
539 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_019E0x019e }, | |||
540 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_019F0x019f }, | |||
541 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A00x01a0 }, | |||
542 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A10x01a1 }, | |||
543 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A20x01a2 }, | |||
544 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A30x01a3 }, | |||
545 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A40x01a4 }, | |||
546 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A50x01a5 }, | |||
547 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A60x01a6 }, | |||
548 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A70x01a7 }, | |||
549 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A80x01a8 }, | |||
550 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01A90x01a9 }, | |||
551 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01AA0x01aa }, | |||
552 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01AB0x01ab }, | |||
553 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01AC0x01ac }, | |||
554 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01AD0x01ad }, | |||
555 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01AE0x01ae }, | |||
556 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01AF0x01af }, | |||
557 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B00x01b0 }, | |||
558 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B10x01b1 }, | |||
559 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B20x01b2 }, | |||
560 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B30x01b3 }, | |||
561 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B40x01b4 }, | |||
562 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B50x01b5 }, | |||
563 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B60x01b6 }, | |||
564 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B70x01b7 }, | |||
565 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B80x01b8 }, | |||
566 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01B90x01b9 }, | |||
567 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01BA0x01ba }, | |||
568 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01BB0x01bb }, | |||
569 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01BC0x01bc }, | |||
570 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01BD0x01bd }, | |||
571 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01BE0x01be }, | |||
572 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01BF0x01bf }, | |||
573 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C00x01c0 }, | |||
574 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C10x01c1 }, | |||
575 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C20x01c2 }, | |||
576 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C30x01c3 }, | |||
577 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C40x01c4 }, | |||
578 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C50x01c5 }, | |||
579 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C60x01c6 }, | |||
580 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C70x01c7 }, | |||
581 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C80x01c8 }, | |||
582 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01C90x01c9 }, | |||
583 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01CA0x01ca }, | |||
584 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01CB0x01cb }, | |||
585 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01CC0x01cc }, | |||
586 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01CD0x01cd }, | |||
587 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01CE0x01ce }, | |||
588 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01CF0x01cf }, | |||
589 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D00x01d0 }, | |||
590 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D10x01d1 }, | |||
591 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D20x01d2 }, | |||
592 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D30x01d3 }, | |||
593 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D40x01d4 }, | |||
594 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D50x01d5 }, | |||
595 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D60x01d6 }, | |||
596 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D70x01d7 }, | |||
597 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D80x01d8 }, | |||
598 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01D90x01d9 }, | |||
599 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01DA0x01da }, | |||
600 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01DB0x01db }, | |||
601 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01DC0x01dc }, | |||
602 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01DD0x01dd }, | |||
603 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01DE0x01de }, | |||
604 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01DF0x01df }, | |||
605 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E00x01e0 }, | |||
606 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E10x01e1 }, | |||
607 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E20x01e2 }, | |||
608 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E30x01e3 }, | |||
609 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E40x01e4 }, | |||
610 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E50x01e5 }, | |||
611 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E60x01e6 }, | |||
612 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E70x01e7 }, | |||
613 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E80x01e8 }, | |||
614 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01E90x01e9 }, | |||
615 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01EA0x01ea }, | |||
616 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01EB0x01eb }, | |||
617 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01EC0x01ec }, | |||
618 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01ED0x01ed }, | |||
619 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01EE0x01ee }, | |||
620 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01EF0x01ef }, | |||
621 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F00x01f0 }, | |||
622 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F10x01f1 }, | |||
623 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F20x01f2 }, | |||
624 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F30x01f3 }, | |||
625 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F40x01f4 }, | |||
626 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F50x01f5 }, | |||
627 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F60x01f6 }, | |||
628 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F70x01f7 }, | |||
629 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F80x01f8 }, | |||
630 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01F90x01f9 }, | |||
631 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01FA0x01fa }, | |||
632 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01FB0x01fb }, | |||
633 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01FC0x01fc }, | |||
634 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01FD0x01fd }, | |||
635 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01FE0x01fe }, | |||
636 | { USB_VENDOR_MATRIXORB0x1b3d, USB_PRODUCT_MATRIXORB_LCD_01FF0x01ff }, | |||
637 | { USB_VENDOR_MECANIQUE0x1781, USB_PRODUCT_MECANIQUE_TELLSTICK0x0c30 }, | |||
638 | { USB_VENDOR_MELCO0x0411, USB_PRODUCT_MELCO_PCOPRS10x00b3 }, | |||
639 | { USB_VENDOR_MOBILITY0x1342, USB_PRODUCT_MOBILITY_ED200H0x0202 }, | |||
640 | { USB_VENDOR_OCT0x0b39, USB_PRODUCT_OCT_US23080x0421 }, | |||
641 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_AD4USB0x8003 }, | |||
642 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_AP485_10x0101 }, | |||
643 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_AP485_20x0104 }, | |||
644 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_DRAK50x0700 }, | |||
645 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_DRAK60x1000 }, | |||
646 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_GOLIATH_MSR0x8005 }, | |||
647 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_GOLIATH_MUX0x8004 }, | |||
648 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_IRAMP0x0500 }, | |||
649 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_LEC0x0300 }, | |||
650 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_MUC0x8001 }, | |||
651 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO1010x0b00 }, | |||
652 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO2160x0e00 }, | |||
653 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO220x0a00 }, | |||
654 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO3030x0c00 }, | |||
655 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO3320x0f00 }, | |||
656 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO440x0900 }, | |||
657 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO6030x0d00 }, | |||
658 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_QUIDO880x0800 }, | |||
659 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB2320x0301 }, | |||
660 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB422_10x0102 }, | |||
661 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB422_20x0105 }, | |||
662 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB485C0x0107 }, | |||
663 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB485S0x0106 }, | |||
664 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB485_10x0100 }, | |||
665 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SB485_20x0103 }, | |||
666 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SERIAL0x0200 }, | |||
667 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_SIMUKEY0x8002 }, | |||
668 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_STAVOVY0x8000 }, | |||
669 | { USB_VENDOR_PAPOUCH0x5050, USB_PRODUCT_PAPOUCH_TMU0x0400 }, | |||
670 | { USB_VENDOR_POSIFLEX0x0d3a, USB_PRODUCT_POSIFLEX_PP7000_10x0300 }, | |||
671 | { USB_VENDOR_POSIFLEX0x0d3a, USB_PRODUCT_POSIFLEX_PP7000_20x0400 }, | |||
672 | { USB_VENDOR_RATOC0x0584, USB_PRODUCT_RATOC_REXUSB60F0xb020 }, | |||
673 | { USB_VENDOR_RTSYSTEMS0x2100, USB_PRODUCT_RTSYSTEMS_CT57B0x9e52 }, | |||
674 | { USB_VENDOR_SACOM0x0ba0, USB_PRODUCT_SACOM_USB485BL0x800d }, | |||
675 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_21010x2101 }, | |||
676 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_21020x2102 }, | |||
677 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_21030x2103 }, | |||
678 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_21040x2104 }, | |||
679 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_21060x9020 }, | |||
680 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2201_10x2211 }, | |||
681 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2201_20x2221 }, | |||
682 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2202_10x2212 }, | |||
683 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2202_20x2222 }, | |||
684 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2203_10x2213 }, | |||
685 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2203_20x2223 }, | |||
686 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2401_10x2411 }, | |||
687 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2401_20x2421 }, | |||
688 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2401_30x2431 }, | |||
689 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2401_40x2441 }, | |||
690 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2402_10x2412 }, | |||
691 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2402_20x2422 }, | |||
692 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2402_30x2432 }, | |||
693 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2402_40x2442 }, | |||
694 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2403_10x2413 }, | |||
695 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2403_20x2423 }, | |||
696 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2403_30x2433 }, | |||
697 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2403_40x2443 }, | |||
698 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_10x2811 }, | |||
699 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_20x2821 }, | |||
700 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_30x2831 }, | |||
701 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_40x2841 }, | |||
702 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_50x2851 }, | |||
703 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_60x2861 }, | |||
704 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_70x2871 }, | |||
705 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2801_80x2881 }, | |||
706 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_10x2812 }, | |||
707 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_20x2822 }, | |||
708 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_30x2832 }, | |||
709 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_40x2842 }, | |||
710 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_50x2852 }, | |||
711 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_60x2862 }, | |||
712 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_70x2872 }, | |||
713 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2802_80x2882 }, | |||
714 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_10x2813 }, | |||
715 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_20x2823 }, | |||
716 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_30x2833 }, | |||
717 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_40x2843 }, | |||
718 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_50x2853 }, | |||
719 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_60x2863 }, | |||
720 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_70x2873 }, | |||
721 | { USB_VENDOR_SEALEVEL0x0c52, USB_PRODUCT_SEALEVEL_2803_80x2883 }, | |||
722 | { USB_VENDOR_STOLLMANN0x0742, USB_PRODUCT_STOLLMANN_ISDN_TA_USBA0x4001 }, | |||
723 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_1740x0007 }, | |||
724 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_1750x0001 }, | |||
725 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_3300x0002 }, | |||
726 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_4350x0003 }, | |||
727 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_5560x0009 }, | |||
728 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_5800x0006 }, | |||
729 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_8450x0004 }, | |||
730 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_SERIAL_10x000a }, | |||
731 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_SERIAL_20xf001 }, | |||
732 | { USB_VENDOR_TESTO0x128d, USB_PRODUCT_TESTO_SERVICE0x0005 }, | |||
733 | { USB_VENDOR_THURLBY0x103e, USB_PRODUCT_THURLBY_QL355P0x03e8 }, | |||
734 | { USB_VENDOR_TML0x1b91, USB_PRODUCT_TML_SERIAL0x0064 }, | |||
735 | { USB_VENDOR_UNKNOWN50x0dcd, USB_PRODUCT_UNKNOWN5_NF_RIC0x0001 } | |||
736 | }; | |||
737 | ||||
738 | int | |||
739 | uftdi_match(struct device *parent, void *match, void *aux) | |||
740 | { | |||
741 | struct usb_attach_arg *uaa = aux; | |||
742 | ||||
743 | if (uaa->iface == NULL((void *)0) || uaa->configno != 1) | |||
744 | return (UMATCH_NONE0); | |||
745 | ||||
746 | if (usb_lookup(uftdi_devs, uaa->vendor, uaa->product)usbd_match_device((const struct usb_devno *)(uftdi_devs), sizeof (uftdi_devs) / sizeof ((uftdi_devs)[0]), sizeof ((uftdi_devs )[0]), (uaa->vendor), (uaa->product)) == NULL((void *)0)) | |||
747 | return (UMATCH_NONE0); | |||
748 | ||||
749 | /* JTAG on USB interface 0 */ | |||
750 | if (uaa->vendor == USB_VENDOR_FTDI0x0403 && | |||
751 | uaa->product == USB_PRODUCT_FTDI_OPENRD0x9e90 && | |||
752 | uaa->ifaceno == 0) | |||
753 | return (UMATCH_NONE0); | |||
754 | ||||
755 | return (UMATCH_VENDOR_PRODUCT_CONF_IFACE8); | |||
756 | } | |||
757 | ||||
758 | void | |||
759 | uftdi_attach(struct device *parent, struct device *self, void *aux) | |||
760 | { | |||
761 | struct uftdi_softc *sc = (struct uftdi_softc *)self; | |||
762 | struct usb_attach_arg *uaa = aux; | |||
763 | usb_interface_descriptor_t *id; | |||
764 | usb_endpoint_descriptor_t *ed; | |||
765 | char *devname = sc->sc_dev.dv_xname; | |||
766 | struct ucom_attach_args uca; | |||
767 | int i; | |||
768 | ||||
769 | sc->sc_udev = uaa->device; | |||
770 | sc->sc_iface = uaa->iface; | |||
771 | ||||
772 | if (uaa->release < 0x0200) { | |||
773 | sc->sc_type = UFTDI_TYPE_SIO; | |||
774 | sc->sc_hdrlen = 1; | |||
775 | } else if (uaa->release == 0x0700 || uaa->release == 0x0800) { | |||
776 | sc->sc_type = UFTDI_TYPE_2232H; | |||
777 | sc->sc_hdrlen = 0; | |||
778 | } else { | |||
779 | sc->sc_type = UFTDI_TYPE_8U232AM; | |||
780 | sc->sc_hdrlen = 0; | |||
781 | } | |||
782 | ||||
783 | uca.bulkin = uca.bulkout = -1; | |||
784 | id = usbd_get_interface_descriptor(sc->sc_iface); | |||
785 | for (i = 0; i < id->bNumEndpoints; i++) { | |||
786 | int addr, dir, attr; | |||
787 | ed = usbd_interface2endpoint_descriptor(sc->sc_iface, i); | |||
788 | if (ed == NULL((void *)0)) { | |||
789 | printf("%s: could not read endpoint descriptor\n", | |||
790 | devname); | |||
791 | goto bad; | |||
792 | } | |||
793 | ||||
794 | addr = ed->bEndpointAddress; | |||
795 | dir = UE_GET_DIR(ed->bEndpointAddress)((ed->bEndpointAddress) & 0x80); | |||
796 | attr = UE_GET_XFERTYPE(ed->bmAttributes)((ed->bmAttributes) & 0x03); | |||
797 | if (dir == UE_DIR_IN0x80 && attr == UE_BULK0x02) { | |||
798 | uca.bulkin = addr; | |||
799 | uca.ibufsize = (UGETW(ed->wMaxPacketSize)(*(u_int16_t *)(ed->wMaxPacketSize)) > 0) ? | |||
800 | UGETW(ed->wMaxPacketSize)(*(u_int16_t *)(ed->wMaxPacketSize)) : UFTDIIBUFSIZE64; | |||
801 | } else if (dir == UE_DIR_OUT0x00 && attr == UE_BULK0x02) { | |||
802 | uca.bulkout = addr; | |||
803 | uca.obufsize = (UGETW(ed->wMaxPacketSize)(*(u_int16_t *)(ed->wMaxPacketSize)) > 0) ? | |||
804 | UGETW(ed->wMaxPacketSize)(*(u_int16_t *)(ed->wMaxPacketSize)) : UFTDIOBUFSIZE64; | |||
805 | uca.obufsize-= sc->sc_hdrlen; | |||
806 | } else { | |||
807 | printf("%s: unexpected endpoint\n", devname); | |||
808 | goto bad; | |||
809 | } | |||
810 | } | |||
811 | if (uca.bulkin == -1) { | |||
812 | printf("%s: Could not find data bulk in\n", | |||
813 | sc->sc_dev.dv_xname); | |||
814 | goto bad; | |||
815 | } | |||
816 | if (uca.bulkout == -1) { | |||
817 | printf("%s: Could not find data bulk out\n", | |||
818 | sc->sc_dev.dv_xname); | |||
819 | goto bad; | |||
820 | } | |||
821 | ||||
822 | if (uaa->iface == NULL((void *)0)) | |||
823 | uca.portno = FTDI_PIT_SIOA1; | |||
824 | else | |||
825 | uca.portno = FTDI_PIT_SIOA1 + id->bInterfaceNumber; | |||
826 | /* bulkin, bulkout set above */ | |||
827 | uca.ibufsizepad = uca.ibufsize; | |||
828 | uca.opkthdrlen = sc->sc_hdrlen; | |||
829 | uca.device = sc->sc_udev; | |||
830 | uca.iface = sc->sc_iface; | |||
831 | uca.methods = &uftdi_methods; | |||
832 | uca.arg = sc; | |||
833 | uca.info = NULL((void *)0); | |||
834 | ||||
835 | DPRINTF(("uftdi: in=0x%x out=0x%x\n", uca.bulkin, uca.bulkout)); | |||
836 | sc->sc_subdev = config_found_sm(self, &uca, ucomprint, ucomsubmatch); | |||
837 | ||||
838 | return; | |||
839 | ||||
840 | bad: | |||
841 | DPRINTF(("uftdi_attach: ATTACH ERROR\n")); | |||
842 | usbd_deactivate(sc->sc_udev); | |||
843 | } | |||
844 | ||||
845 | int | |||
846 | uftdi_detach(struct device *self, int flags) | |||
847 | { | |||
848 | struct uftdi_softc *sc = (struct uftdi_softc *)self; | |||
849 | ||||
850 | DPRINTF(("uftdi_detach: sc=%p flags=%d\n", sc, flags)); | |||
851 | if (sc->sc_subdev != NULL((void *)0)) { | |||
852 | config_detach(sc->sc_subdev, flags); | |||
853 | sc->sc_subdev = NULL((void *)0); | |||
854 | } | |||
855 | ||||
856 | return (0); | |||
857 | } | |||
858 | ||||
859 | int | |||
860 | uftdi_open(void *vsc, int portno) | |||
861 | { | |||
862 | struct uftdi_softc *sc = vsc; | |||
863 | usb_device_request_t req; | |||
864 | usbd_status err; | |||
865 | struct termios t; | |||
866 | ||||
867 | DPRINTF(("uftdi_open: sc=%p\n", sc)); | |||
868 | ||||
869 | if (usbd_is_dying(sc->sc_udev)) | |||
| ||||
870 | return (EIO5); | |||
871 | ||||
872 | /* Perform a full reset on the device */ | |||
873 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
874 | req.bRequest = FTDI_SIO_RESET0; | |||
875 | USETW(req.wValue, FTDI_SIO_RESET_SIO)(*(u_int16_t *)(req.wValue) = (0)); | |||
876 | USETW(req.wIndex, portno)(*(u_int16_t *)(req.wIndex) = (portno)); | |||
877 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
878 | err = usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
879 | if (err) | |||
880 | return (EIO5); | |||
881 | ||||
882 | /* Set 9600 baud, 2 stop bits, no parity, 8 bits */ | |||
883 | t.c_ospeed = 9600; | |||
884 | t.c_cflag = CSTOPB0x00000400 | CS80x00000300; | |||
885 | (void)uftdi_param(sc, portno, &t); | |||
886 | ||||
887 | /* Turn on RTS/CTS flow control */ | |||
888 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
889 | req.bRequest = FTDI_SIO_SET_FLOW_CTRL2; | |||
890 | USETW(req.wValue, 0)(*(u_int16_t *)(req.wValue) = (0)); | |||
891 | USETW2(req.wIndex, FTDI_SIO_RTS_CTS_HS, portno)((req.wIndex)[0] = (u_int8_t)(portno), (req.wIndex)[1] = (u_int8_t )(0x1)); | |||
892 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
893 | err = usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
894 | if (err) | |||
895 | return (EIO5); | |||
896 | ||||
897 | return (0); | |||
898 | } | |||
899 | ||||
900 | void | |||
901 | uftdi_read(void *vsc, int portno, u_char **ptr, u_int32_t *count) | |||
902 | { | |||
903 | struct uftdi_softc *sc = vsc; | |||
904 | u_char msr, lsr; | |||
905 | ||||
906 | DPRINTFN(15,("uftdi_read: sc=%p, port=%d count=%d\n", sc, portno, | |||
907 | *count)); | |||
908 | ||||
909 | msr = FTDI_GET_MSR(*ptr)(((*ptr)[0]) & 0xf0); | |||
910 | lsr = FTDI_GET_LSR(*ptr)((*ptr)[1]); | |||
911 | ||||
912 | #ifdef UFTDI_DEBUG | |||
913 | if (*count != 2) | |||
914 | DPRINTFN(10,("uftdi_read: sc=%p, port=%d count=%d data[0]=" | |||
915 | "0x%02x\n", sc, portno, *count, (*ptr)[2])); | |||
916 | #endif | |||
917 | ||||
918 | if (sc->sc_msr != msr || | |||
919 | (sc->sc_lsr & FTDI_LSR_MASK(~0x60)) != (lsr & FTDI_LSR_MASK(~0x60))) { | |||
920 | DPRINTF(("uftdi_read: status change msr=0x%02x(0x%02x) " | |||
921 | "lsr=0x%02x(0x%02x)\n", msr, sc->sc_msr, | |||
922 | lsr, sc->sc_lsr)); | |||
923 | sc->sc_msr = msr; | |||
924 | sc->sc_lsr = lsr; | |||
925 | ucom_status_change((struct ucom_softc *)sc->sc_subdev); | |||
926 | } | |||
927 | ||||
928 | /* Pick up status and adjust data part. */ | |||
929 | *ptr += 2; | |||
930 | *count -= 2; | |||
931 | } | |||
932 | ||||
933 | void | |||
934 | uftdi_write(void *vsc, int portno, u_char *to, u_char *from, u_int32_t *count) | |||
935 | { | |||
936 | struct uftdi_softc *sc = vsc; | |||
937 | ||||
938 | DPRINTFN(10,("uftdi_write: sc=%p, port=%d count=%u data[0]=0x%02x\n", | |||
939 | vsc, portno, *count, from[0])); | |||
940 | ||||
941 | /* Make length tag and copy data */ | |||
942 | if (sc->sc_hdrlen > 0) | |||
943 | *to = FTDI_OUT_TAG(*count, portno)(((*count) << 2) | (portno)); | |||
944 | ||||
945 | memcpy(to + sc->sc_hdrlen, from, *count)__builtin_memcpy((to + sc->sc_hdrlen), (from), (*count)); | |||
946 | *count += sc->sc_hdrlen; | |||
947 | } | |||
948 | ||||
949 | void | |||
950 | uftdi_set(void *vsc, int portno, int reg, int onoff) | |||
951 | { | |||
952 | struct uftdi_softc *sc = vsc; | |||
953 | usb_device_request_t req; | |||
954 | int ctl; | |||
955 | ||||
956 | DPRINTF(("uftdi_set: sc=%p, port=%d reg=%d onoff=%d\n", vsc, portno, | |||
957 | reg, onoff)); | |||
958 | ||||
959 | switch (reg) { | |||
960 | case UCOM_SET_DTR1: | |||
961 | ctl = onoff ? FTDI_SIO_SET_DTR_HIGH(1 | ( 0x1 << 8)) : FTDI_SIO_SET_DTR_LOW(0 | ( 0x1 << 8)); | |||
962 | break; | |||
963 | case UCOM_SET_RTS2: | |||
964 | ctl = onoff ? FTDI_SIO_SET_RTS_HIGH(2 | ( 0x2 << 8)) : FTDI_SIO_SET_RTS_LOW(0 | ( 0x2 << 8)); | |||
965 | break; | |||
966 | case UCOM_SET_BREAK3: | |||
967 | uftdi_break(sc, portno, onoff); | |||
968 | return; | |||
969 | default: | |||
970 | return; | |||
971 | } | |||
972 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
973 | req.bRequest = FTDI_SIO_MODEM_CTRL1; | |||
974 | USETW(req.wValue, ctl)(*(u_int16_t *)(req.wValue) = (ctl)); | |||
975 | USETW(req.wIndex, portno)(*(u_int16_t *)(req.wIndex) = (portno)); | |||
976 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
977 | DPRINTFN(2,("uftdi_set: reqtype=0x%02x req=0x%02x value=0x%04x " | |||
978 | "index=0x%04x len=%d\n", req.bmRequestType, req.bRequest, | |||
979 | UGETW(req.wValue), UGETW(req.wIndex), UGETW(req.wLength))); | |||
980 | (void)usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
981 | } | |||
982 | ||||
983 | int | |||
984 | uftdi_param(void *vsc, int portno, struct termios *t) | |||
985 | { | |||
986 | struct uftdi_softc *sc = vsc; | |||
987 | usb_device_request_t req; | |||
988 | usbd_status err; | |||
989 | int rate, data, flow; | |||
990 | ||||
991 | DPRINTF(("uftdi_param: sc=%p\n", sc)); | |||
992 | ||||
993 | if (usbd_is_dying(sc->sc_udev)) | |||
994 | return (EIO5); | |||
995 | ||||
996 | switch (sc->sc_type) { | |||
997 | case UFTDI_TYPE_SIO: | |||
998 | switch (t->c_ospeed) { | |||
999 | case 300: rate = ftdi_sio_b300; break; | |||
1000 | case 600: rate = ftdi_sio_b600; break; | |||
1001 | case 1200: rate = ftdi_sio_b1200; break; | |||
1002 | case 2400: rate = ftdi_sio_b2400; break; | |||
1003 | case 4800: rate = ftdi_sio_b4800; break; | |||
1004 | case 9600: rate = ftdi_sio_b9600; break; | |||
1005 | case 19200: rate = ftdi_sio_b19200; break; | |||
1006 | case 38400: rate = ftdi_sio_b38400; break; | |||
1007 | case 57600: rate = ftdi_sio_b57600; break; | |||
1008 | case 115200: rate = ftdi_sio_b115200; break; | |||
1009 | default: | |||
1010 | return (EINVAL22); | |||
1011 | } | |||
1012 | break; | |||
1013 | ||||
1014 | case UFTDI_TYPE_8U232AM: | |||
1015 | if (uftdi_8u232am_getrate(t->c_ospeed, &rate) == -1) | |||
1016 | return (EINVAL22); | |||
1017 | break; | |||
1018 | case UFTDI_TYPE_2232H: | |||
1019 | if (uftdi_2232h_getrate(t->c_ospeed, &rate) == -1) | |||
1020 | return (EINVAL22); | |||
1021 | break; | |||
1022 | } | |||
1023 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
1024 | req.bRequest = FTDI_SIO_SET_BAUD_RATE3; | |||
1025 | USETW(req.wValue, rate)(*(u_int16_t *)(req.wValue) = (rate)); | |||
1026 | USETW(req.wIndex, ((rate >> 8) & 0xFF00) | portno)(*(u_int16_t *)(req.wIndex) = (((rate >> 8) & 0xFF00 ) | portno)); | |||
1027 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
1028 | DPRINTFN(2,("uftdi_param: reqtype=0x%02x req=0x%02x value=0x%04x " | |||
1029 | "index=0x%04x len=%d\n", req.bmRequestType, req.bRequest, | |||
1030 | UGETW(req.wValue), UGETW(req.wIndex), UGETW(req.wLength))); | |||
1031 | err = usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
1032 | if (err) | |||
1033 | return (EIO5); | |||
1034 | ||||
1035 | if (ISSET(t->c_cflag, CSTOPB)((t->c_cflag) & (0x00000400))) | |||
1036 | data = FTDI_SIO_SET_DATA_STOP_BITS_2(0x2 << 11); | |||
1037 | else | |||
1038 | data = FTDI_SIO_SET_DATA_STOP_BITS_1(0x0 << 11); | |||
1039 | if (ISSET(t->c_cflag, PARENB)((t->c_cflag) & (0x00001000))) { | |||
1040 | if (ISSET(t->c_cflag, PARODD)((t->c_cflag) & (0x00002000))) | |||
1041 | data |= FTDI_SIO_SET_DATA_PARITY_ODD(0x1 << 8); | |||
1042 | else | |||
1043 | data |= FTDI_SIO_SET_DATA_PARITY_EVEN(0x2 << 8); | |||
1044 | } else | |||
1045 | data |= FTDI_SIO_SET_DATA_PARITY_NONE(0x0 << 8); | |||
1046 | switch (ISSET(t->c_cflag, CSIZE)((t->c_cflag) & (0x00000300))) { | |||
1047 | case CS50x00000000: | |||
1048 | data |= FTDI_SIO_SET_DATA_BITS(5)(5); | |||
1049 | break; | |||
1050 | case CS60x00000100: | |||
1051 | data |= FTDI_SIO_SET_DATA_BITS(6)(6); | |||
1052 | break; | |||
1053 | case CS70x00000200: | |||
1054 | data |= FTDI_SIO_SET_DATA_BITS(7)(7); | |||
1055 | break; | |||
1056 | case CS80x00000300: | |||
1057 | data |= FTDI_SIO_SET_DATA_BITS(8)(8); | |||
1058 | break; | |||
1059 | } | |||
1060 | sc->last_lcr = data; | |||
1061 | ||||
1062 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
1063 | req.bRequest = FTDI_SIO_SET_DATA4; | |||
1064 | USETW(req.wValue, data)(*(u_int16_t *)(req.wValue) = (data)); | |||
1065 | USETW(req.wIndex, portno)(*(u_int16_t *)(req.wIndex) = (portno)); | |||
1066 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
1067 | DPRINTFN(2,("uftdi_param: reqtype=0x%02x req=0x%02x value=0x%04x " | |||
1068 | "index=0x%04x len=%d\n", req.bmRequestType, req.bRequest, | |||
1069 | UGETW(req.wValue), UGETW(req.wIndex), UGETW(req.wLength))); | |||
1070 | err = usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
1071 | if (err) | |||
1072 | return (EIO5); | |||
1073 | ||||
1074 | if (ISSET(t->c_cflag, CRTSCTS)((t->c_cflag) & (0x00010000))) { | |||
1075 | flow = FTDI_SIO_RTS_CTS_HS0x1; | |||
1076 | USETW(req.wValue, 0)(*(u_int16_t *)(req.wValue) = (0)); | |||
1077 | } else if (ISSET(t->c_iflag, IXON|IXOFF)((t->c_iflag) & (0x00000200|0x00000400))) { | |||
| ||||
1078 | flow = FTDI_SIO_XON_XOFF_HS0x4; | |||
1079 | USETW2(req.wValue, t->c_cc[VSTOP], t->c_cc[VSTART])((req.wValue)[0] = (u_int8_t)(t->c_cc[12]), (req.wValue)[1 ] = (u_int8_t)(t->c_cc[13])); | |||
1080 | } else { | |||
1081 | flow = FTDI_SIO_DISABLE_FLOW_CTRL0x0; | |||
1082 | USETW(req.wValue, 0)(*(u_int16_t *)(req.wValue) = (0)); | |||
1083 | } | |||
1084 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
1085 | req.bRequest = FTDI_SIO_SET_FLOW_CTRL2; | |||
1086 | USETW2(req.wIndex, flow, portno)((req.wIndex)[0] = (u_int8_t)(portno), (req.wIndex)[1] = (u_int8_t )(flow)); | |||
1087 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
1088 | err = usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
1089 | if (err) | |||
1090 | return (EIO5); | |||
1091 | ||||
1092 | return (0); | |||
1093 | } | |||
1094 | ||||
1095 | void | |||
1096 | uftdi_get_status(void *vsc, int portno, u_char *lsr, u_char *msr) | |||
1097 | { | |||
1098 | struct uftdi_softc *sc = vsc; | |||
1099 | ||||
1100 | DPRINTF(("uftdi_status: msr=0x%02x lsr=0x%02x\n", | |||
1101 | sc->sc_msr, sc->sc_lsr)); | |||
1102 | ||||
1103 | if (msr != NULL((void *)0)) | |||
1104 | *msr = sc->sc_msr; | |||
1105 | if (lsr != NULL((void *)0)) | |||
1106 | *lsr = sc->sc_lsr; | |||
1107 | } | |||
1108 | ||||
1109 | void | |||
1110 | uftdi_break(void *vsc, int portno, int onoff) | |||
1111 | { | |||
1112 | struct uftdi_softc *sc = vsc; | |||
1113 | usb_device_request_t req; | |||
1114 | int data; | |||
1115 | ||||
1116 | DPRINTF(("uftdi_break: sc=%p, port=%d onoff=%d\n", vsc, portno, | |||
1117 | onoff)); | |||
1118 | ||||
1119 | if (onoff) { | |||
1120 | data = sc->last_lcr | FTDI_SIO_SET_BREAK(0x1 << 14); | |||
1121 | } else { | |||
1122 | data = sc->last_lcr; | |||
1123 | } | |||
1124 | ||||
1125 | req.bmRequestType = UT_WRITE_VENDOR_DEVICE(0x00 | 0x40 | 0x00); | |||
1126 | req.bRequest = FTDI_SIO_SET_DATA4; | |||
1127 | USETW(req.wValue, data)(*(u_int16_t *)(req.wValue) = (data)); | |||
1128 | USETW(req.wIndex, portno)(*(u_int16_t *)(req.wIndex) = (portno)); | |||
1129 | USETW(req.wLength, 0)(*(u_int16_t *)(req.wLength) = (0)); | |||
1130 | (void)usbd_do_request(sc->sc_udev, &req, NULL((void *)0)); | |||
1131 | } | |||
1132 | ||||
1133 | int | |||
1134 | uftdi_8u232am_getrate(speed_t speed, int *rate) | |||
1135 | { | |||
1136 | /* Table of the nearest even powers-of-2 for values 0..15. */ | |||
1137 | static const unsigned char roundoff[16] = { | |||
1138 | 0, 2, 2, 4, 4, 4, 8, 8, | |||
1139 | 8, 8, 8, 8, 16, 16, 16, 16, | |||
1140 | }; | |||
1141 | ||||
1142 | unsigned int d, freq; | |||
1143 | int result; | |||
1144 | ||||
1145 | if (speed <= 0) | |||
1146 | return (-1); | |||
1147 | ||||
1148 | /* Special cases for 2M and 3M. */ | |||
1149 | if (speed >= 3000000 * 100 / 103 && | |||
1150 | speed <= 3000000 * 100 / 97) { | |||
1151 | result = 0; | |||
1152 | goto done; | |||
1153 | } | |||
1154 | if (speed >= 2000000 * 100 / 103 && | |||
1155 | speed <= 2000000 * 100 / 97) { | |||
1156 | result = 1; | |||
1157 | goto done; | |||
1158 | } | |||
1159 | ||||
1160 | d = (FTDI_8U232AM_FREQ3000000 << 4) / speed; | |||
1161 | d = (d & ~15) + roundoff[d & 15]; | |||
1162 | ||||
1163 | if (d < FTDI_8U232AM_MIN_DIV0x20) | |||
1164 | d = FTDI_8U232AM_MIN_DIV0x20; | |||
1165 | else if (d > FTDI_8U232AM_MAX_DIV0x3fff8) | |||
1166 | d = FTDI_8U232AM_MAX_DIV0x3fff8; | |||
1167 | ||||
1168 | /* | |||
1169 | * Calculate the frequency needed for d to exactly divide down | |||
1170 | * to our target speed, and check that the actual frequency is | |||
1171 | * within 3% of this. | |||
1172 | */ | |||
1173 | freq = speed * d; | |||
1174 | if (freq < (quad_t)(FTDI_8U232AM_FREQ3000000 << 4) * 100 / 103 || | |||
1175 | freq > (quad_t)(FTDI_8U232AM_FREQ3000000 << 4) * 100 / 97) | |||
1176 | return (-1); | |||
1177 | ||||
1178 | /* | |||
1179 | * Pack the divisor into the resultant value. The lower | |||
1180 | * 14-bits hold the integral part, while the upper 2 bits | |||
1181 | * encode the fractional component: either 0, 0.5, 0.25, or | |||
1182 | * 0.125. | |||
1183 | */ | |||
1184 | result = d >> 4; | |||
1185 | if (d & 8) | |||
1186 | result |= 0x4000; | |||
1187 | else if (d & 4) | |||
1188 | result |= 0x8000; | |||
1189 | else if (d & 2) | |||
1190 | result |= 0xc000; | |||
1191 | ||||
1192 | done: | |||
1193 | *rate = result; | |||
1194 | return (0); | |||
1195 | } | |||
1196 | ||||
1197 | int | |||
1198 | uftdi_2232h_getrate(speed_t speed, int *rate) | |||
1199 | { | |||
1200 | char sub[8] = {0, 3, 2, 4, 1, 5, 6, 7}; | |||
1201 | int n = (FTDI_2232H_FREQ12000000 << 3) / speed; | |||
1202 | int s = n & 7; | |||
1203 | int result = (n >> 3) | (sub[s] << 14); | |||
1204 | int resultspeed, accuracy; | |||
1205 | ||||
1206 | /* Special cases */ | |||
1207 | if (result == 1) | |||
1208 | result = 0; | |||
1209 | else if (result == 0x4001) | |||
1210 | result = 1; | |||
1211 | ||||
1212 | /* Check if resulting baud rate is within 3%. */ | |||
1213 | if (result == 0) | |||
1214 | goto done; | |||
1215 | resultspeed = (FTDI_2232H_FREQ12000000 << 3) / | |||
1216 | (((result & 0x00003FFF) << 3) | s); | |||
1217 | accuracy = (abs(speed - resultspeed) * 100) / speed; | |||
1218 | if (accuracy > 3) | |||
1219 | return -1; | |||
1220 | ||||
1221 | done: | |||
1222 | result|= 0x00020000; /* Set this bit to turn off a divide by 2.5 */ | |||
1223 | *rate = result; | |||
1224 | return 0; | |||
1225 | } |