]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - 6/sys/dev/usb/usb_quirks.c
Clone Kip's Xen on stable/6 tree so that I can work on improving FreeBSD/amd64
[FreeBSD/FreeBSD.git] / 6 / sys / dev / usb / usb_quirks.c
1 /*      $NetBSD: usb_quirks.c,v 1.50 2004/06/23 02:30:52 mycroft Exp $  */
2
3 /*-
4  * Copyright (c) 1998 The NetBSD Foundation, Inc.
5  * All rights reserved.
6  *
7  * This code is derived from software contributed to The NetBSD Foundation
8  * by Lennart Augustsson (lennart@augustsson.net) at
9  * Carlstedt Research & Technology.
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  * 3. All advertising materials mentioning features or use of this software
20  *    must display the following acknowledgement:
21  *        This product includes software developed by the NetBSD
22  *        Foundation, Inc. and its contributors.
23  * 4. Neither the name of The NetBSD Foundation nor the names of its
24  *    contributors may be used to endorse or promote products derived
25  *    from this software without specific prior written permission.
26  *
27  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
28  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
29  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
30  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
31  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
32  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
33  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
34  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
35  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
36  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
37  * POSSIBILITY OF SUCH DAMAGE.
38  */
39
40 #include <sys/cdefs.h>
41 __FBSDID("$FreeBSD$");
42
43 #include <sys/param.h>
44 #include <sys/systm.h>
45
46 #include <dev/usb/usb.h>
47
48 #include "usbdevs.h"
49 #include <dev/usb/usb_quirks.h>
50
51 #ifdef USB_DEBUG
52 extern int usbdebug;
53 #endif
54
55 #define ANY 0xffff
56
57 Static const struct usbd_quirk_entry {
58         u_int16_t idVendor;
59         u_int16_t idProduct;
60         u_int16_t bcdDevice;
61         struct usbd_quirks quirks;
62 } usb_quirks[] = {
63  { USB_VENDOR_KYE, USB_PRODUCT_KYE_NICHE,           0x100, { UQ_NO_SET_PROTO}},
64  { USB_VENDOR_INSIDEOUT, USB_PRODUCT_INSIDEOUT_EDGEPORT4,
65                                                     0x094, { UQ_SWAP_UNICODE}},
66  { USB_VENDOR_DALLAS, USB_PRODUCT_DALLAS_J6502,     0x0a2, { UQ_BAD_ADC }},
67  { USB_VENDOR_DALLAS, USB_PRODUCT_DALLAS_J6502,     0x0a2, { UQ_AU_NO_XU }},
68  { USB_VENDOR_ALTEC, USB_PRODUCT_ALTEC_ADA70,       0x103, { UQ_BAD_ADC }},
69  { USB_VENDOR_ALTEC, USB_PRODUCT_ALTEC_ASC495,      0x000, { UQ_BAD_AUDIO }},
70  { USB_VENDOR_QTRONIX, USB_PRODUCT_QTRONIX_980N,    0x110, { UQ_SPUR_BUT_UP }},
71  { USB_VENDOR_ALCOR2, USB_PRODUCT_ALCOR2_KBD_HUB,   0x001, { UQ_SPUR_BUT_UP }},
72  { USB_VENDOR_MCT, USB_PRODUCT_MCT_HUB0100,         0x102, { UQ_BUS_POWERED }},
73  { USB_VENDOR_MCT, USB_PRODUCT_MCT_USB232,          0x102, { UQ_BUS_POWERED }},
74  { USB_VENDOR_METRICOM, USB_PRODUCT_METRICOM_RICOCHET_GS,
75         0x100, { UQ_ASSUME_CM_OVER_DATA }},
76  { USB_VENDOR_SANYO, USB_PRODUCT_SANYO_SCP4900,
77         0x000, { UQ_ASSUME_CM_OVER_DATA }},
78  { USB_VENDOR_TI, USB_PRODUCT_TI_UTUSB41,           0x110, { UQ_POWER_CLAIM }},
79  { USB_VENDOR_TELEX, USB_PRODUCT_TELEX_MIC1,        0x009, { UQ_AU_NO_FRAC }},
80  { USB_VENDOR_SILICONPORTALS, USB_PRODUCT_SILICONPORTALS_YAPPHONE,
81                                                     0x100, { UQ_AU_INP_ASYNC }},
82  { USB_VENDOR_LOGITECH, USB_PRODUCT_LOGITECH_UN53B, ANY, { UQ_NO_STRINGS }},
83  { USB_VENDOR_CMOTECH, USB_PRODUCT_CMOTECH_CNU510,
84          ANY, { UQ_ASSUME_CM_OVER_DATA }},
85  { USB_VENDOR_CMOTECH, USB_PRODUCT_CMOTECH_CNU550,
86          ANY, { UQ_ASSUME_CM_OVER_DATA }},
87  { USB_VENDOR_CURITEL, USB_PRODUCT_CURITEL_HX550C,
88          ANY, { UQ_ASSUME_CM_OVER_DATA }},
89  { USB_VENDOR_CURITEL, USB_PRODUCT_CURITEL_HX57XB,
90          ANY, { UQ_ASSUME_CM_OVER_DATA }},
91  { USB_VENDOR_UBIQUAM, USB_PRODUCT_UBIQUAM_UALL,
92          ANY, { UQ_ASSUME_CM_OVER_DATA }},
93  { USB_VENDOR_QUALCOMM, USB_PRODUCT_QUALCOMM_RWT_FCT,
94          ANY, { UQ_ASSUME_CM_OVER_DATA }},
95  /* XXX These should have a revision number, but I don't know what they are. */
96  { USB_VENDOR_HP, USB_PRODUCT_HP_895C,              ANY,   { UQ_BROKEN_BIDIR }},
97  { USB_VENDOR_HP, USB_PRODUCT_HP_880C,              ANY,   { UQ_BROKEN_BIDIR }},
98  { USB_VENDOR_HP, USB_PRODUCT_HP_815C,              ANY,   { UQ_BROKEN_BIDIR }},
99  { USB_VENDOR_HP, USB_PRODUCT_HP_810C,              ANY,   { UQ_BROKEN_BIDIR }},
100  { USB_VENDOR_HP, USB_PRODUCT_HP_830C,              ANY,   { UQ_BROKEN_BIDIR }},
101  { USB_VENDOR_HP, USB_PRODUCT_HP_1220C,             ANY,   { UQ_BROKEN_BIDIR }},
102  { USB_VENDOR_XEROX, USB_PRODUCT_XEROX_WCM15,       ANY,   { UQ_BROKEN_BIDIR }},
103  /* YAMAHA router's ucdDevice is the version of farmware and often changes. */
104  { USB_VENDOR_YAMAHA, USB_PRODUCT_YAMAHA_RTA54I,
105         ANY, { UQ_ASSUME_CM_OVER_DATA }},
106  { USB_VENDOR_YAMAHA, USB_PRODUCT_YAMAHA_RTA55I,
107         ANY, { UQ_ASSUME_CM_OVER_DATA }},
108  { USB_VENDOR_YAMAHA, USB_PRODUCT_YAMAHA_RTW65B,
109         ANY, { UQ_ASSUME_CM_OVER_DATA }},
110  { USB_VENDOR_YAMAHA, USB_PRODUCT_YAMAHA_RTW65I,
111         ANY, { UQ_ASSUME_CM_OVER_DATA }},
112  { USB_VENDOR_QUALCOMM, USB_PRODUCT_QUALCOMM_CDMA_MSM,
113         ANY, { UQ_ASSUME_CM_OVER_DATA }},
114  { USB_VENDOR_QUALCOMM2, USB_PRODUCT_QUALCOMM2_CDMA_MSM,
115         ANY, { UQ_ASSUME_CM_OVER_DATA }},
116  { USB_VENDOR_SUNTAC, USB_PRODUCT_SUNTAC_AS64LX,
117         0x100, { UQ_ASSUME_CM_OVER_DATA }},
118  { USB_VENDOR_MOTOROLA2, USB_PRODUCT_MOTOROLA2_A41XV32X,
119         ANY, { UQ_ASSUME_CM_OVER_DATA }},
120  /* Devices which should be ignored by uhid */
121  { USB_VENDOR_APC, USB_PRODUCT_APC_UPS,
122         ANY, { UQ_HID_IGNORE }},
123  { USB_VENDOR_BELKIN, USB_PRODUCT_BELKIN_F6C550AVR,
124         ANY, { UQ_HID_IGNORE }},
125  { USB_VENDOR_DELORME, USB_PRODUCT_DELORME_EARTHMATE,
126         ANY, { UQ_HID_IGNORE }},
127  { USB_VENDOR_MGE, USB_PRODUCT_MGE_UPS1,
128         ANY, { UQ_HID_IGNORE }},
129  { USB_VENDOR_MGE, USB_PRODUCT_MGE_UPS2,
130         ANY, { UQ_HID_IGNORE }},
131  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_IPHONE,
132         ANY, { UQ_HID_IGNORE }},
133  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_IPHONE_3G,
134         ANY, { UQ_HID_IGNORE }},
135
136  /* Devices which should be ignored by both ukbd and uhid */
137  { USB_VENDOR_CYPRESS, USB_PRODUCT_CYPRESS_WISPY,
138         ANY, { UQ_KBD_IGNORE }},
139  { 0, 0, 0, { 0 } }
140 };
141
142 const struct usbd_quirks usbd_no_quirk = { 0 };
143
144 const struct usbd_quirks *
145 usbd_find_quirk(usb_device_descriptor_t *d)
146 {
147         const struct usbd_quirk_entry *t;
148         u_int16_t vendor = UGETW(d->idVendor);
149         u_int16_t product = UGETW(d->idProduct);
150         u_int16_t revision = UGETW(d->bcdDevice);
151
152         for (t = usb_quirks; t->idVendor != 0; t++) {
153                 if (t->idVendor  == vendor &&
154                     t->idProduct == product &&
155                     (t->bcdDevice == ANY || t->bcdDevice == revision))
156                         break;
157         }
158 #ifdef USB_DEBUG
159         if (usbdebug && t->quirks.uq_flags)
160                 logprintf("usbd_find_quirk 0x%04x/0x%04x/%x: %d\n",
161                           UGETW(d->idVendor), UGETW(d->idProduct),
162                           UGETW(d->bcdDevice), t->quirks.uq_flags);
163 #endif
164         return (&t->quirks);
165 }