diff options
author | Fernando Luis Vázquez Cao <fernando_b1@lab.ntt.co.jp> | 2013-01-15 05:40:48 -0500 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2013-01-15 11:01:11 -0500 |
commit | a464918419f94a0043d2f549d6defb4c3f69f68a (patch) | |
tree | 3a5d1106bfbf5d36d10a856ea2bbd879ae4baf76 /drivers/hid | |
parent | e57a67da600408c6f15c453a48c386d0f17188dd (diff) |
HID: add support for Sony RF receiver with USB product id 0x0374
Some Vaio desktop computers, among them the VGC-LN51JGB multimedia PC, have
a RF receiver, multi-interface USB device 054c:0374, that is used to connect
a wireless keyboard and a wireless mouse.
The keyboard works flawlessly, but the mouse (VGP-WMS3 in my case) does not
seem to be generating any pointer events. The problem is that the mouse pointer
is wrongly declared as a constant non-data variable in the report descriptor
(see lsusb and usbhid-dump output below), with the consequence that it is
ignored by the HID code.
Add this device to the have-special-driver list and fix up the report
descriptor in the Sony-specific driver which happens to already have a fixup
for a similar firmware bug.
# lsusb -vd 054C:0374
Bus 003 Device 002: ID 054c:0374 Sony Corp.
Device Descriptor:
bLength 18
bDescriptorType 1
bcdUSB 2.00
bDeviceClass 0 (Defined at Interface level)
bDeviceSubClass 0
bDeviceProtocol 0
bMaxPacketSize0 8
idVendor 0x054c Sony Corp.
idProduct 0x0374
iSerial 0
[...]
Interface Descriptor:
bLength 9
bDescriptorType 4
bInterfaceNumber 1
bAlternateSetting 0
bNumEndpoints 1
bInterfaceClass 3 Human Interface Device
bInterfaceSubClass 1 Boot Interface Subclass
bInterfaceProtocol 2 Mouse
iInterface 2 RF Receiver
[...]
Report Descriptor: (length is 100)
[...]
Item(Global): Usage Page, data= [ 0x01 ] 1
Generic Desktop Controls
Item(Local ): Usage, data= [ 0x30 ] 48
Direction-X
Item(Local ): Usage, data= [ 0x31 ] 49
Direction-Y
Item(Global): Report Count, data= [ 0x02 ] 2
Item(Global): Report Size, data= [ 0x08 ] 8
Item(Global): Logical Minimum, data= [ 0x81 ] 129
Item(Global): Logical Maximum, data= [ 0x7f ] 127
Item(Main ): Input, data= [ 0x07 ] 7
Constant Variable Relative No_Wrap Linear
Preferred_State No_Null_Position Non_Volatile Bitfield
# usbhid-dump
003:002:001:DESCRIPTOR 1357910009.758544
05 01 09 02 A1 01 05 01 09 02 A1 02 85 01 09 01
A1 00 05 09 19 01 29 05 95 05 75 01 15 00 25 01
81 02 75 03 95 01 81 01 05 01 09 30 09 31 95 02
75 08 15 81 25 7F 81 07 A1 02 85 01 09 38 35 00
45 00 15 81 25 7F 95 01 75 08 81 06 C0 A1 02 85
01 05 0C 15 81 25 7F 95 01 75 08 0A 38 02 81 06
C0 C0 C0 C0
Cc: linux-input@vger.kernel.org
Cc: linux-usb@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Fernando Luis Vazquez Cao <fernando@oss.ntt.co.jp>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid')
-rw-r--r-- | drivers/hid/hid-core.c | 1 | ||||
-rw-r--r-- | drivers/hid/hid-ids.h | 1 | ||||
-rw-r--r-- | drivers/hid/hid-sony.c | 4 |
3 files changed, 5 insertions, 1 deletions
diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c index eb2ee11b6412..1651728b5aa4 100644 --- a/drivers/hid/hid-core.c +++ b/drivers/hid/hid-core.c | |||
@@ -1697,6 +1697,7 @@ static const struct hid_device_id hid_have_special_driver[] = { | |||
1697 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_NAVIGATION_CONTROLLER) }, | 1697 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_NAVIGATION_CONTROLLER) }, |
1698 | { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS3_CONTROLLER) }, | 1698 | { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS3_CONTROLLER) }, |
1699 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE) }, | 1699 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE) }, |
1700 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGP_MOUSE) }, | ||
1700 | { HID_USB_DEVICE(USB_VENDOR_ID_SUNPLUS, USB_DEVICE_ID_SUNPLUS_WDESKTOP) }, | 1701 | { HID_USB_DEVICE(USB_VENDOR_ID_SUNPLUS, USB_DEVICE_ID_SUNPLUS_WDESKTOP) }, |
1701 | { HID_USB_DEVICE(USB_VENDOR_ID_THRUSTMASTER, 0xb300) }, | 1702 | { HID_USB_DEVICE(USB_VENDOR_ID_THRUSTMASTER, 0xb300) }, |
1702 | { HID_USB_DEVICE(USB_VENDOR_ID_THRUSTMASTER, 0xb304) }, | 1703 | { HID_USB_DEVICE(USB_VENDOR_ID_THRUSTMASTER, 0xb304) }, |
diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h index 4dfa605e2d14..50ac9097db2f 100644 --- a/drivers/hid/hid-ids.h +++ b/drivers/hid/hid-ids.h | |||
@@ -706,6 +706,7 @@ | |||
706 | 706 | ||
707 | #define USB_VENDOR_ID_SONY 0x054c | 707 | #define USB_VENDOR_ID_SONY 0x054c |
708 | #define USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE 0x024b | 708 | #define USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE 0x024b |
709 | #define USB_DEVICE_ID_SONY_VAIO_VGP_MOUSE 0x0374 | ||
709 | #define USB_DEVICE_ID_SONY_PS3_BDREMOTE 0x0306 | 710 | #define USB_DEVICE_ID_SONY_PS3_BDREMOTE 0x0306 |
710 | #define USB_DEVICE_ID_SONY_PS3_CONTROLLER 0x0268 | 711 | #define USB_DEVICE_ID_SONY_PS3_CONTROLLER 0x0268 |
711 | #define USB_DEVICE_ID_SONY_NAVIGATION_CONTROLLER 0x042f | 712 | #define USB_DEVICE_ID_SONY_NAVIGATION_CONTROLLER 0x042f |
diff --git a/drivers/hid/hid-sony.c b/drivers/hid/hid-sony.c index 16df4d84f525..6d2d459e9a5a 100644 --- a/drivers/hid/hid-sony.c +++ b/drivers/hid/hid-sony.c | |||
@@ -67,7 +67,7 @@ static __u8 *sony_report_fixup(struct hid_device *hdev, __u8 *rdesc, | |||
67 | 67 | ||
68 | if ((sc->quirks & VAIO_RDESC_CONSTANT) && | 68 | if ((sc->quirks & VAIO_RDESC_CONSTANT) && |
69 | *rsize >= 56 && rdesc[54] == 0x81 && rdesc[55] == 0x07) { | 69 | *rsize >= 56 && rdesc[54] == 0x81 && rdesc[55] == 0x07) { |
70 | hid_info(hdev, "Fixing up Sony Vaio VGX report descriptor\n"); | 70 | hid_info(hdev, "Fixing up Sony RF Receiver report descriptor\n"); |
71 | rdesc[55] = 0x06; | 71 | rdesc[55] = 0x06; |
72 | } | 72 | } |
73 | 73 | ||
@@ -245,6 +245,8 @@ static const struct hid_device_id sony_devices[] = { | |||
245 | .driver_data = SIXAXIS_CONTROLLER_BT }, | 245 | .driver_data = SIXAXIS_CONTROLLER_BT }, |
246 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE), | 246 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE), |
247 | .driver_data = VAIO_RDESC_CONSTANT }, | 247 | .driver_data = VAIO_RDESC_CONSTANT }, |
248 | { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGP_MOUSE), | ||
249 | .driver_data = VAIO_RDESC_CONSTANT }, | ||
248 | { } | 250 | { } |
249 | }; | 251 | }; |
250 | MODULE_DEVICE_TABLE(hid, sony_devices); | 252 | MODULE_DEVICE_TABLE(hid, sony_devices); |