Skip to content

Commit 1113ed2

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 5190914 commit 1113ed2

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
@@ -243,6 +243,9 @@
243243
#define USB_VENDOR_ID_BAANTO 0x2453
244244
#define USB_DEVICE_ID_BAANTO_MT_190W2 0x0100
245245

246+
#define USB_VENDOR_ID_BEKEN 0x25a7
247+
#define USB_DEVICE_ID_AIRMOUSE_T3 0x2402
248+
246249
#define USB_VENDOR_ID_BELKIN 0x050d
247250
#define USB_DEVICE_ID_FLIP_KVM 0x3201
248251

@@ -1416,6 +1419,9 @@
14161419
#define USB_VENDOR_ID_XIAOMI 0x2717
14171420
#define USB_DEVICE_ID_MI_SILENT_MOUSE 0x5014
14181421

1422+
#define USB_VENDOR_ID_XENTA 0x1d57
1423+
#define USB_DEVICE_ID_AIRMOUSE_MX3 0xad03
1424+
14191425
#define USB_VENDOR_ID_XIN_MO 0x16c0
14201426
#define USB_DEVICE_ID_XIN_MO_DUAL_ARCADE 0x05e1
14211427
#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)