aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/hid/usbhid/hid-quirks.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/drivers/hid/usbhid/hid-quirks.c b/drivers/hid/usbhid/hid-quirks.c
index 68b38fdb1203..30f63e9f93a3 100644
--- a/drivers/hid/usbhid/hid-quirks.c
+++ b/drivers/hid/usbhid/hid-quirks.c
@@ -341,6 +341,9 @@
341#define USB_VENDOR_ID_SAITEK 0x06a3 341#define USB_VENDOR_ID_SAITEK 0x06a3
342#define USB_DEVICE_ID_SAITEK_RUMBLEPAD 0xff17 342#define USB_DEVICE_ID_SAITEK_RUMBLEPAD 0xff17
343 343
344#define USB_VENDOR_ID_SAMSUNG 0x0419
345#define USB_DEVICE_ID_SAMSUNG_IR_REMOTE 0x0001
346
344#define USB_VENDOR_ID_SONY 0x054c 347#define USB_VENDOR_ID_SONY 0x054c
345#define USB_DEVICE_ID_SONY_PS3_CONTROLLER 0x0268 348#define USB_DEVICE_ID_SONY_PS3_CONTROLLER 0x0268
346 349
@@ -673,6 +676,8 @@ static const struct hid_rdesc_blacklist {
673 676
674 { USB_VENDOR_ID_PETALYNX, USB_DEVICE_ID_PETALYNX_MAXTER_REMOTE, HID_QUIRK_RDESC_PETALYNX }, 677 { USB_VENDOR_ID_PETALYNX, USB_DEVICE_ID_PETALYNX_MAXTER_REMOTE, HID_QUIRK_RDESC_PETALYNX },
675 678
679 { USB_VENDOR_ID_SAMSUNG, USB_DEVICE_ID_SAMSUNG_IR_REMOTE, HID_QUIRK_RDESC_SAMSUNG_REMOTE },
680
676 { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_1, HID_QUIRK_RDESC_SWAPPED_MIN_MAX }, 681 { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_1, HID_QUIRK_RDESC_SWAPPED_MIN_MAX },
677 { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_2, HID_QUIRK_RDESC_SWAPPED_MIN_MAX }, 682 { USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_2, HID_QUIRK_RDESC_SWAPPED_MIN_MAX },
678 683
@@ -947,6 +952,33 @@ static void usbhid_fixup_logitech_descriptor(unsigned char *rdesc, int rsize)
947 } 952 }
948} 953}
949 954
955/*
956 * Samsung IrDA remote controller (reports as Cypress USB Mouse).
957 *
958 * Vendor specific report #4 has a size of 48 bit,
959 * and therefore is not accepted when inspecting the descriptors.
960 * As a workaround we reinterpret the report as:
961 * Variable type, count 6, size 8 bit, log. maximum 255
962 * The burden to reconstruct the data is moved into user space.
963 */
964static void usbhid_fixup_samsung_irda_descriptor(unsigned char *rdesc,
965 int rsize)
966{
967 if (rsize >= 182 && rdesc[175] == 0x25
968 && rdesc[176] == 0x40
969 && rdesc[177] == 0x75
970 && rdesc[178] == 0x30
971 && rdesc[179] == 0x95
972 && rdesc[180] == 0x01
973 && rdesc[182] == 0x40) {
974 printk(KERN_INFO "Fixing up Samsung IrDA report descriptor\n");
975 rdesc[176] = 0xff;
976 rdesc[178] = 0x08;
977 rdesc[180] = 0x06;
978 rdesc[182] = 0x42;
979 }
980}
981
950/* Petalynx Maxter Remote has maximum for consumer page set too low */ 982/* Petalynx Maxter Remote has maximum for consumer page set too low */
951static void usbhid_fixup_petalynx_descriptor(unsigned char *rdesc, int rsize) 983static void usbhid_fixup_petalynx_descriptor(unsigned char *rdesc, int rsize)
952{ 984{
@@ -1026,6 +1058,10 @@ static void __usbhid_fixup_report_descriptor(__u32 quirks, char *rdesc, unsigned
1026 1058
1027 if (quirks & HID_QUIRK_RDESC_BUTTON_CONSUMER) 1059 if (quirks & HID_QUIRK_RDESC_BUTTON_CONSUMER)
1028 usbhid_fixup_button_consumer_descriptor(rdesc, rsize); 1060 usbhid_fixup_button_consumer_descriptor(rdesc, rsize);
1061
1062 if (quirks & HID_QUIRK_RDESC_SAMSUNG_REMOTE)
1063 usbhid_fixup_samsung_irda_descriptor(rdesc, rsize);
1064
1029} 1065}
1030 1066
1031/** 1067/**