Skip to content

Commit f6c6a6e

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 1f3cc0c commit f6c6a6e

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

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

@@ -1423,6 +1426,9 @@
14231426
#define USB_VENDOR_ID_XIAOMI 0x2717
14241427
#define USB_DEVICE_ID_MI_SILENT_MOUSE 0x5014
14251428

1429+
#define USB_VENDOR_ID_XENTA 0x1d57
1430+
#define USB_DEVICE_ID_AIRMOUSE_MX3 0xad03
1431+
14261432
#define USB_VENDOR_ID_XIN_MO 0x16c0
14271433
#define USB_DEVICE_ID_XIN_MO_DUAL_ARCADE 0x05e1
14281434
#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)