Home | History | Annotate | Line # | Download | only in usb
usb_quirks.c revision 1.74
      1  1.74    plunky /*	$NetBSD: usb_quirks.c,v 1.74 2012/02/11 05:27:23 plunky Exp $	*/
      2  1.42       imp /*	$FreeBSD: src/sys/dev/usb/usb_quirks.c,v 1.30 2003/01/02 04:15:55 imp Exp $	*/
      3   1.1  augustss 
      4   1.1  augustss /*
      5  1.52   mycroft  * Copyright (c) 1998, 2004 The NetBSD Foundation, Inc.
      6   1.1  augustss  * All rights reserved.
      7   1.1  augustss  *
      8   1.2  augustss  * This code is derived from software contributed to The NetBSD Foundation
      9  1.26  augustss  * by Lennart Augustsson (lennart (at) augustsson.net) at
     10   1.2  augustss  * Carlstedt Research & Technology.
     11   1.1  augustss  *
     12   1.1  augustss  * Redistribution and use in source and binary forms, with or without
     13   1.1  augustss  * modification, are permitted provided that the following conditions
     14   1.1  augustss  * are met:
     15   1.1  augustss  * 1. Redistributions of source code must retain the above copyright
     16   1.1  augustss  *    notice, this list of conditions and the following disclaimer.
     17   1.1  augustss  * 2. Redistributions in binary form must reproduce the above copyright
     18   1.1  augustss  *    notice, this list of conditions and the following disclaimer in the
     19   1.1  augustss  *    documentation and/or other materials provided with the distribution.
     20   1.1  augustss  *
     21   1.1  augustss  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     22   1.1  augustss  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     23   1.1  augustss  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     24   1.1  augustss  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     25   1.1  augustss  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     26   1.1  augustss  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     27   1.1  augustss  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     28   1.1  augustss  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     29   1.1  augustss  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     30   1.1  augustss  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     31   1.1  augustss  * POSSIBILITY OF SUCH DAMAGE.
     32   1.1  augustss  */
     33  1.39     lukem 
     34  1.39     lukem #include <sys/cdefs.h>
     35  1.74    plunky __KERNEL_RCSID(0, "$NetBSD: usb_quirks.c,v 1.74 2012/02/11 05:27:23 plunky Exp $");
     36   1.1  augustss 
     37   1.1  augustss #include <sys/param.h>
     38   1.1  augustss #include <sys/systm.h>
     39  1.40  augustss 
     40   1.1  augustss #include <dev/usb/usb.h>
     41   1.1  augustss 
     42   1.1  augustss #include <dev/usb/usbdevs.h>
     43   1.1  augustss #include <dev/usb/usb_quirks.h>
     44   1.1  augustss 
     45   1.7  augustss #ifdef USB_DEBUG
     46   1.7  augustss extern int usbdebug;
     47   1.7  augustss #endif
     48   1.7  augustss 
     49  1.38  augustss #define ANY 0xffff
     50  1.37  augustss 
     51  1.36  jdolecek Static const struct usbd_quirk_entry {
     52   1.1  augustss 	u_int16_t idVendor;
     53   1.1  augustss 	u_int16_t idProduct;
     54   1.1  augustss 	u_int16_t bcdDevice;
     55   1.1  augustss 	struct usbd_quirks quirks;
     56  1.15  augustss } usb_quirks[] = {
     57  1.57     veego  /* Devices which should be ignored by uhid */
     58  1.57     veego  { USB_VENDOR_APC, USB_PRODUCT_APC_UPS,		    ANY,   { UQ_HID_IGNORE }},
     59  1.63  jakllsch  { USB_VENDOR_CYBERPOWER, USB_PRODUCT_CYBERPOWER_UPS, ANY, { UQ_HID_IGNORE }},
     60  1.57     veego  { USB_VENDOR_MGE, USB_PRODUCT_MGE_UPS1,	    ANY,   { UQ_HID_IGNORE }},
     61  1.57     veego  { USB_VENDOR_MGE, USB_PRODUCT_MGE_UPS2,	    ANY,   { UQ_HID_IGNORE }},
     62  1.64  jakllsch  { USB_VENDOR_MICROCHIP,  USB_PRODUCT_MICROCHIP_PICKIT1,
     63  1.64  jakllsch 	ANY,	{ UQ_HID_IGNORE }},
     64  1.73  jakllsch  { USB_VENDOR_TRIPPLITE2, USB_PRODUCT_TRIPPLITE2_UPS,
     65  1.58     rafal 	ANY,   { UQ_HID_IGNORE }},
     66  1.74    plunky  { USB_VENDOR_MISC, USB_PRODUCT_MISC_WISPY_24X, ANY, { UQ_HID_IGNORE }},
     67  1.61     rmind 
     68  1.14  augustss  { USB_VENDOR_KYE, USB_PRODUCT_KYE_NICHE,	    0x100, { UQ_NO_SET_PROTO}},
     69  1.40  augustss  { USB_VENDOR_INSIDEOUT, USB_PRODUCT_INSIDEOUT_EDGEPORT4,
     70   1.1  augustss    						    0x094, { UQ_SWAP_UNICODE}},
     71  1.14  augustss  { USB_VENDOR_DALLAS, USB_PRODUCT_DALLAS_J6502,	    0x0a2, { UQ_BAD_ADC }},
     72  1.34  augustss  { USB_VENDOR_DALLAS, USB_PRODUCT_DALLAS_J6502,	    0x0a2, { UQ_AU_NO_XU }},
     73  1.22  augustss  { USB_VENDOR_ALTEC, USB_PRODUCT_ALTEC_ADA70,	    0x103, { UQ_BAD_ADC }},
     74  1.17  augustss  { USB_VENDOR_ALTEC, USB_PRODUCT_ALTEC_ASC495,      0x000, { UQ_BAD_AUDIO }},
     75  1.51  hamajima  { USB_VENDOR_SONY, USB_PRODUCT_SONY_PS2EYETOY4,    0x000, { UQ_BAD_AUDIO }},
     76  1.51  hamajima  { USB_VENDOR_SONY, USB_PRODUCT_SONY_PS2EYETOY5,    0x000, { UQ_BAD_AUDIO }},
     77  1.54  jmcneill  { USB_VENDOR_PHILIPS, USB_PRODUCT_PHILIPS_PCVC740K,  ANY, { UQ_BAD_AUDIO }},
     78  1.49  hamajima  { USB_VENDOR_LOGITECH, USB_PRODUCT_LOGITECH_QUICKCAMPRONB,
     79  1.49  hamajima 	0x000, { UQ_BAD_AUDIO }},
     80  1.49  hamajima  { USB_VENDOR_LOGITECH, USB_PRODUCT_LOGITECH_QUICKCAMPRO4K,
     81  1.49  hamajima 	0x000, { UQ_BAD_AUDIO }},
     82  1.62  jmcneill  { USB_VENDOR_LOGITECH, USB_PRODUCT_LOGITECH_QUICKCAMMESS,
     83  1.62  jmcneill 	0x100, { UQ_BAD_ADC }},
     84  1.18  augustss  { USB_VENDOR_QTRONIX, USB_PRODUCT_QTRONIX_980N,    0x110, { UQ_SPUR_BUT_UP }},
     85  1.28  augustss  { USB_VENDOR_ALCOR2, USB_PRODUCT_ALCOR2_KBD_HUB,   0x001, { UQ_SPUR_BUT_UP }},
     86  1.29  explorer  { USB_VENDOR_METRICOM, USB_PRODUCT_METRICOM_RICOCHET_GS,
     87  1.50   mycroft  	0x100, { UQ_ASSUME_CM_OVER_DATA }},
     88  1.42       imp  { USB_VENDOR_SANYO, USB_PRODUCT_SANYO_SCP4900,
     89  1.50   mycroft  	0x000, { UQ_ASSUME_CM_OVER_DATA }},
     90  1.46  augustss  { USB_VENDOR_MOTOROLA2, USB_PRODUCT_MOTOROLA2_T720C,
     91  1.46  augustss  	0x001, { UQ_ASSUME_CM_OVER_DATA }},
     92  1.47  augustss  { USB_VENDOR_EICON, USB_PRODUCT_EICON_DIVA852,
     93  1.47  augustss         0x100, { UQ_ASSUME_CM_OVER_DATA }},
     94  1.53  augustss  { USB_VENDOR_SIEMENS2, USB_PRODUCT_SIEMENS2_MC75,
     95  1.53  augustss         0x000, { UQ_ASSUME_CM_OVER_DATA }},
     96  1.34  augustss  { USB_VENDOR_TELEX, USB_PRODUCT_TELEX_MIC1,	    0x009, { UQ_AU_NO_FRAC }},
     97  1.34  augustss  { USB_VENDOR_SILICONPORTALS, USB_PRODUCT_SILICONPORTALS_YAPPHONE,
     98  1.34  augustss    						    0x100, { UQ_AU_INP_ASYNC }},
     99  1.43  jdolecek  { USB_VENDOR_AVANCELOGIC, USB_PRODUCT_AVANCELOGIC_USBAUDIO,
    100  1.43  jdolecek    						    0x101, { UQ_AU_INP_ASYNC }},
    101  1.45  hamajima  { USB_VENDOR_PLANTRONICS, USB_PRODUCT_PLANTRONICS_HEADSET,
    102  1.45  hamajima    						    0x004, { UQ_AU_INP_ASYNC }},
    103  1.37  augustss  /* XXX These should have a revision number, but I don't know what they are. */
    104  1.38  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_895C,		    ANY,   { UQ_BROKEN_BIDIR }},
    105  1.38  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_880C,		    ANY,   { UQ_BROKEN_BIDIR }},
    106  1.38  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_815C,		    ANY,   { UQ_BROKEN_BIDIR }},
    107  1.38  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_810C,		    ANY,   { UQ_BROKEN_BIDIR }},
    108  1.38  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_830C,		    ANY,   { UQ_BROKEN_BIDIR }},
    109  1.48  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_885C,		    ANY,   { UQ_BROKEN_BIDIR }},
    110  1.48  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_840C,		    ANY,   { UQ_BROKEN_BIDIR }},
    111  1.48  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_816C,		    ANY,   { UQ_BROKEN_BIDIR }},
    112  1.48  augustss  { USB_VENDOR_HP, USB_PRODUCT_HP_959C,		    ANY,   { UQ_BROKEN_BIDIR }},
    113  1.67    kardel  { USB_VENDOR_MTK, USB_PRODUCT_MTK_GPS_RECEIVER,    ANY,   { UQ_NO_UNION_NRM }},
    114  1.48  augustss  { USB_VENDOR_NEC, USB_PRODUCT_NEC_PICTY900,	    ANY,   { UQ_BROKEN_BIDIR }},
    115  1.48  augustss  { USB_VENDOR_NEC, USB_PRODUCT_NEC_PICTY760,	    ANY,   { UQ_BROKEN_BIDIR }},
    116  1.48  augustss  { USB_VENDOR_NEC, USB_PRODUCT_NEC_PICTY920,	    ANY,   { UQ_BROKEN_BIDIR }},
    117  1.48  augustss  { USB_VENDOR_NEC, USB_PRODUCT_NEC_PICTY800,	    ANY,   { UQ_BROKEN_BIDIR }},
    118  1.48  augustss 
    119  1.42       imp  { USB_VENDOR_HP, USB_PRODUCT_HP_1220C,		    ANY,   { UQ_BROKEN_BIDIR }},
    120  1.56      salo 
    121  1.70       phx  /* Apple internal notebook ISO keyboards have swapped keys */
    122  1.70       phx  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_FOUNTAIN_ISO,
    123  1.70       phx 	ANY, { UQ_APPLE_ISO }},
    124  1.70       phx  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_GEYSER_ISO,
    125  1.70       phx 	ANY, { UQ_APPLE_ISO }},
    126  1.70       phx 
    127  1.60  jmcneill  /* HID and audio are both invalid on iPhone/iPod Touch */
    128  1.60  jmcneill  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_IPHONE,
    129  1.60  jmcneill 	ANY, { UQ_HID_IGNORE | UQ_BAD_AUDIO }},
    130  1.60  jmcneill  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_IPOD_TOUCH,
    131  1.60  jmcneill 	ANY, { UQ_HID_IGNORE | UQ_BAD_AUDIO }},
    132  1.60  jmcneill  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_IPHONE_3G,
    133  1.60  jmcneill 	ANY, { UQ_HID_IGNORE | UQ_BAD_AUDIO }},
    134  1.66  explorer  { USB_VENDOR_APPLE, USB_PRODUCT_APPLE_IPHONE_3GS,
    135  1.66  explorer 	ANY, { UQ_HID_IGNORE | UQ_BAD_AUDIO }},
    136  1.60  jmcneill 
    137  1.56      salo  { USB_VENDOR_QUALCOMM, USB_PRODUCT_QUALCOMM_CDMA_MSM,
    138  1.56      salo 	ANY, { UQ_ASSUME_CM_OVER_DATA }},
    139  1.56      salo  { USB_VENDOR_QUALCOMM2, USB_PRODUCT_QUALCOMM2_CDMA_MSM,
    140  1.56      salo 	ANY, { UQ_ASSUME_CM_OVER_DATA }},
    141  1.65  jakllsch  { USB_VENDOR_HYUNDAI, USB_PRODUCT_HYUNDAI_UM175,
    142  1.65  jakllsch 	ANY, { UQ_ASSUME_CM_OVER_DATA }},
    143  1.68  christos  { USB_VENDOR_ZOOM, USB_PRODUCT_ZOOM_3095,
    144  1.68  christos 	ANY, { UQ_LOST_CS_DESC }},
    145   1.1  augustss  { 0, 0, 0, { 0 } }
    146   1.1  augustss };
    147   1.1  augustss 
    148  1.36  jdolecek const struct usbd_quirks usbd_no_quirk = { 0 };
    149   1.1  augustss 
    150  1.36  jdolecek const struct usbd_quirks *
    151  1.27  augustss usbd_find_quirk(usb_device_descriptor_t *d)
    152   1.1  augustss {
    153  1.36  jdolecek 	const struct usbd_quirk_entry *t;
    154  1.37  augustss 	u_int16_t vendor = UGETW(d->idVendor);
    155  1.37  augustss 	u_int16_t product = UGETW(d->idProduct);
    156  1.37  augustss 	u_int16_t revision = UGETW(d->bcdDevice);
    157   1.1  augustss 
    158  1.15  augustss 	for (t = usb_quirks; t->idVendor != 0; t++) {
    159  1.37  augustss 		if (t->idVendor  == vendor &&
    160  1.37  augustss 		    t->idProduct == product &&
    161  1.38  augustss 		    (t->bcdDevice == ANY || t->bcdDevice == revision))
    162   1.1  augustss 			break;
    163   1.1  augustss 	}
    164   1.1  augustss #ifdef USB_DEBUG
    165   1.1  augustss 	if (usbdebug && t->quirks.uq_flags)
    166  1.69    dyoung 		printf("usbd_find_quirk 0x%04x/0x%04x/%x: %d\n",
    167  1.12  augustss 			  UGETW(d->idVendor), UGETW(d->idProduct),
    168  1.12  augustss 			  UGETW(d->bcdDevice), t->quirks.uq_flags);
    169   1.1  augustss #endif
    170   1.1  augustss 	return (&t->quirks);
    171   1.1  augustss }
    172