| 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 | } |