d07b889
From 98f07385212073536f303c07ece455acdd4d267f Mon Sep 17 00:00:00 2001
d07b889
From: =?UTF-8?q?=D0=9D=D0=B8=D0=BA=D0=BE=D0=BB=D0=B0=D0=B9=20=D0=9A=D1=83?=
d07b889
 =?UTF-8?q?=D0=B4=D1=80=D1=8F=D0=B2=D1=86=D0=B5=D0=B2?=
d07b889
 <nkudriavtsev@gmail.com>
d07b889
Date: Tue, 21 Jul 2015 13:31:52 +0300
d07b889
Subject: [PATCH] HID: chicony: Add support for Acer Aspire Switch 12
d07b889
d07b889
Acer Aspire Switch 12 keyboard Chicony's controller reports too big usage
d07b889
index on the 1st interface. The patch fixes the report. The work based on
d07b889
solution from drivers/hid/hid-holtek-mouse.c
d07b889
d07b889
Bug report: https://bugzilla.kernel.org/show_bug.cgi?id=101721
d07b889
d07b889
Signed-off-by: Nicholas Kudriavtsev <nkudriavtsev@gmail.com>
d07b889
Signed-off-by: Jiri Kosina <jkosina@suse.com>
d07b889
---
d07b889
 drivers/hid/hid-chicony.c | 26 ++++++++++++++++++++++++++
d07b889
 drivers/hid/hid-core.c    |  1 +
d07b889
 drivers/hid/hid-ids.h     |  1 +
d07b889
 3 files changed, 28 insertions(+)
d07b889
d07b889
diff --git a/drivers/hid/hid-chicony.c b/drivers/hid/hid-chicony.c
d07b889
index b613d5a79684..bc3cec199fee 100644
d07b889
--- a/drivers/hid/hid-chicony.c
d07b889
+++ b/drivers/hid/hid-chicony.c
d07b889
@@ -20,6 +20,7 @@
d07b889
 #include <linux/input.h>
d07b889
 #include <linux/hid.h>
d07b889
 #include <linux/module.h>
d07b889
+#include <linux/usb.h>
d07b889
 
d07b889
 #include "hid-ids.h"
d07b889
 
d07b889
@@ -57,10 +58,34 @@ static int ch_input_mapping(struct hid_device *hdev, struct hid_input *hi,
d07b889
 	return 1;
d07b889
 }
d07b889
 
d07b889
+static __u8 *ch_switch12_report_fixup(struct hid_device *hdev, __u8 *rdesc,
d07b889
+		unsigned int *rsize)
d07b889
+{
d07b889
+	struct usb_interface *intf = to_usb_interface(hdev->dev.parent);
d07b889
+	
d07b889
+	if (intf->cur_altsetting->desc.bInterfaceNumber == 1) {
d07b889
+		/* Change usage maximum and logical maximum from 0x7fff to
d07b889
+		 * 0x2fff, so they don't exceed HID_MAX_USAGES */
d07b889
+		switch (hdev->product) {
d07b889
+		case USB_DEVICE_ID_CHICONY_ACER_SWITCH12:
d07b889
+			if (*rsize >= 128 && rdesc[64] == 0xff && rdesc[65] == 0x7f
d07b889
+					&& rdesc[69] == 0xff && rdesc[70] == 0x7f) {
d07b889
+				hid_info(hdev, "Fixing up report descriptor\n");
d07b889
+				rdesc[65] = rdesc[70] = 0x2f;
d07b889
+			}
d07b889
+			break;
d07b889
+		}
d07b889
+
d07b889
+	}
d07b889
+	return rdesc;
d07b889
+}
d07b889
+
d07b889
+
d07b889
 static const struct hid_device_id ch_devices[] = {
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_TACTICAL_PAD) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_WIRELESS2) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_AK1D) },
d07b889
+	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_ACER_SWITCH12) },
d07b889
 	{ }
d07b889
 };
d07b889
 MODULE_DEVICE_TABLE(hid, ch_devices);
d07b889
@@ -68,6 +93,7 @@ MODULE_DEVICE_TABLE(hid, ch_devices);
d07b889
 static struct hid_driver ch_driver = {
d07b889
 	.name = "chicony",
d07b889
 	.id_table = ch_devices,
d07b889
+	.report_fixup = ch_switch12_report_fixup,
d07b889
 	.input_mapping = ch_input_mapping,
d07b889
 };
d07b889
 module_hid_driver(ch_driver);
d07b889
diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c
d07b889
index e6fce23b121a..f90ca6574221 100644
d07b889
--- a/drivers/hid/hid-core.c
d07b889
+++ b/drivers/hid/hid-core.c
d07b889
@@ -1807,6 +1807,7 @@ static const struct hid_device_id hid_have_special_driver[] = {
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_WIRELESS) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_WIRELESS2) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_AK1D) },
d07b889
+	{ HID_USB_DEVICE(USB_VENDOR_ID_CHICONY, USB_DEVICE_ID_CHICONY_ACER_SWITCH12) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CREATIVELABS, USB_DEVICE_ID_PRODIKEYS_PCMIDI) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CYGNAL, USB_DEVICE_ID_CYGNAL_CP2112) },
d07b889
 	{ HID_USB_DEVICE(USB_VENDOR_ID_CYPRESS, USB_DEVICE_ID_CYPRESS_BARCODE_1) },
d07b889
diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h
d07b889
index b3b225b75d0a..79210ca8eff1 100644
d07b889
--- a/drivers/hid/hid-ids.h
d07b889
+++ b/drivers/hid/hid-ids.h
d07b889
@@ -233,6 +233,7 @@
d07b889
 #define USB_DEVICE_ID_CHICONY_PIXART_USB_OPTICAL_MOUSE	0x1053
d07b889
 #define USB_DEVICE_ID_CHICONY_WIRELESS2	0x1123
d07b889
 #define USB_DEVICE_ID_CHICONY_AK1D	0x1125
d07b889
+#define USB_DEVICE_ID_CHICONY_ACER_SWITCH12	0x1421
d07b889
 
d07b889
 #define USB_VENDOR_ID_CHUNGHWAT		0x2247
d07b889
 #define USB_DEVICE_ID_CHUNGHWAT_MULTITOUCH	0x0001
d07b889
-- 
d07b889
2.4.3
d07b889