From: Andrew Shadura Date: Thu, 29 Oct 2015 15:09:49 +0000 (+0100) Subject: HID: penmount: report only one button for PenMount 6000 USB touchscreen controller X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=5f66872cbd9c2d8e5230da571aed52d9333a04ae;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git HID: penmount: report only one button for PenMount 6000 USB touchscreen controller PenMount 6000 USB resistive touchscreen controller reports it has three buttons, while in reality it doesn't have any and doesn't support active styli, and only generates touch events. In penmount_input_mapping(), map only the first button (with code 0), ignore the rest. Signed-off-by: Andrew Shadura Tested-by: Christian Gmeiner --- diff --git a/drivers/hid/hid-penmount.c b/drivers/hid/hid-penmount.c index c11dce85cd18..d90383f788e2 100644 --- a/drivers/hid/hid-penmount.c +++ b/drivers/hid/hid-penmount.c @@ -23,8 +23,12 @@ static int penmount_input_mapping(struct hid_device *hdev, struct hid_usage *usage, unsigned long **bit, int *max) { if ((usage->hid & HID_USAGE_PAGE) == HID_UP_BUTTON) { - hid_map_usage(hi, usage, bit, max, EV_KEY, BTN_TOUCH); - return 1; + if (((usage->hid - 1) & HID_USAGE) == 0) { + hid_map_usage(hi, usage, bit, max, EV_KEY, BTN_TOUCH); + return 1; + } else { + return -1; + } } return 0;