Skip to content

Commit 3202fbf

Browse files
Jonathan Bellpopcornmix
Jonathan Bell
authored andcommitted
hid: usb: Add device quirks for Freeway Airmouse T3 and MX3
These wireless mouse/keyboard combo remote control devices specify multiple "wheel" events in their report descriptors. The wheel events are incorrectly defined and apparently map to accelerometer data, leading to spurious mouse scroll events being generated at an extreme rate when the device is moved. As a workaround, use HID_QUIRK_INCREMENT_USAGE_ON_DUPLICATE to mask feeding the extra wheel events to the input subsystem. See: raspberrypi/firmware#1189 Signed-off-by: Jonathan Bell <[email protected]>
1 parent 19e38a6 commit 3202fbf

File tree

2 files changed

+8
-0
lines changed

2 files changed

+8
-0
lines changed

drivers/hid/hid-ids.h

+6
Original file line numberDiff line numberDiff line change
@@ -250,6 +250,9 @@
250250
#define USB_VENDOR_ID_BAANTO 0x2453
251251
#define USB_DEVICE_ID_BAANTO_MT_190W2 0x0100
252252

253+
#define USB_VENDOR_ID_BEKEN 0x25a7
254+
#define USB_DEVICE_ID_AIRMOUSE_T3 0x2402
255+
253256
#define USB_VENDOR_ID_BELKIN 0x050d
254257
#define USB_DEVICE_ID_FLIP_KVM 0x3201
255258

@@ -1462,6 +1465,9 @@
14621465
#define USB_VENDOR_ID_XIAOMI 0x2717
14631466
#define USB_DEVICE_ID_MI_SILENT_MOUSE 0x5014
14641467

1468+
#define USB_VENDOR_ID_XENTA 0x1d57
1469+
#define USB_DEVICE_ID_AIRMOUSE_MX3 0xad03
1470+
14651471
#define USB_VENDOR_ID_XIN_MO 0x16c0
14661472
#define USB_DEVICE_ID_XIN_MO_DUAL_ARCADE 0x05e1
14671473
#define USB_DEVICE_ID_THT_2P_ARCADE 0x75e1

drivers/hid/hid-quirks.c

+2
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ static const struct hid_device_id hid_quirks[] = {
4242
{ HID_USB_DEVICE(USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_CS682), HID_QUIRK_NOGET },
4343
{ HID_USB_DEVICE(USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_CS692), HID_QUIRK_NOGET },
4444
{ HID_USB_DEVICE(USB_VENDOR_ID_ATEN, USB_DEVICE_ID_ATEN_UC100KM), HID_QUIRK_NOGET },
45+
{ HID_USB_DEVICE(USB_VENDOR_ID_BEKEN, USB_DEVICE_ID_AIRMOUSE_T3), HID_QUIRK_INCREMENT_USAGE_ON_DUPLICATE },
4546
{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_MULTI_TOUCH), HID_QUIRK_MULTI_INPUT },
4647
{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_PIXART_USB_OPTICAL_MOUSE), HID_QUIRK_ALWAYS_POLL },
4748
{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_PIXART_USB_OPTICAL_MOUSE2), HID_QUIRK_ALWAYS_POLL },
@@ -209,6 +210,7 @@ static const struct hid_device_id hid_quirks[] = {
209210
{ HID_USB_DEVICE(USB_VENDOR_ID_WISEGROUP, USB_DEVICE_ID_QUAD_USB_JOYPAD), HID_QUIRK_NOGET | HID_QUIRK_MULTI_INPUT },
210211
{ HID_USB_DEVICE(USB_VENDOR_ID_XIN_MO, USB_DEVICE_ID_XIN_MO_DUAL_ARCADE), HID_QUIRK_MULTI_INPUT },
211212
{ HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_GROUP_AUDIO), HID_QUIRK_NOGET },
213+
{ HID_USB_DEVICE(USB_VENDOR_ID_XENTA, USB_DEVICE_ID_AIRMOUSE_MX3), HID_QUIRK_INCREMENT_USAGE_ON_DUPLICATE },
212214

213215
{ 0 }
214216
};

0 commit comments

Comments
 (0)