aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hid/hid-lg.c
diff options
context:
space:
mode:
authorNikolai Kondrashov <spbnick@gmail.com>2010-08-06 15:03:06 -0400
committerJiri Kosina <jkosina@suse.cz>2010-08-09 13:52:42 -0400
commit73e4008ddddc84d5f2499c17012b340a0dae153e (patch)
treed3adfa8c5792e71c21cb7a9cd18517cce9c92685 /drivers/hid/hid-lg.c
parent3cfc2c42c1cbc8e238bb9c0612c0df4565e3a8b4 (diff)
HID: allow resizing and replacing report descriptors
Update hid_driver's report_fixup prototype to allow changing report descriptor size and/or returning completely different report descriptor. Update existing usage accordingly. This is to give more freedom in descriptor fixup and to allow having a whole fixed descriptor in the code for the sake of readability. Signed-off-by: Nikolai Kondrashov <spbnick@gmail.com> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid/hid-lg.c')
-rw-r--r--drivers/hid/hid-lg.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/hid/hid-lg.c b/drivers/hid/hid-lg.c
index f6433d8050a..68c0b68856c 100644
--- a/drivers/hid/hid-lg.c
+++ b/drivers/hid/hid-lg.c
@@ -41,25 +41,26 @@
41 * above the logical maximum described in descriptor. This extends 41 * above the logical maximum described in descriptor. This extends
42 * the original value of 0x28c of logical maximum to 0x104d 42 * the original value of 0x28c of logical maximum to 0x104d
43 */ 43 */
44static void lg_report_fixup(struct hid_device *hdev, __u8 *rdesc, 44static __u8 *lg_report_fixup(struct hid_device *hdev, __u8 *rdesc,
45 unsigned int rsize) 45 unsigned int *rsize)
46{ 46{
47 unsigned long quirks = (unsigned long)hid_get_drvdata(hdev); 47 unsigned long quirks = (unsigned long)hid_get_drvdata(hdev);
48 48
49 if ((quirks & LG_RDESC) && rsize >= 90 && rdesc[83] == 0x26 && 49 if ((quirks & LG_RDESC) && *rsize >= 90 && rdesc[83] == 0x26 &&
50 rdesc[84] == 0x8c && rdesc[85] == 0x02) { 50 rdesc[84] == 0x8c && rdesc[85] == 0x02) {
51 dev_info(&hdev->dev, "fixing up Logitech keyboard report " 51 dev_info(&hdev->dev, "fixing up Logitech keyboard report "
52 "descriptor\n"); 52 "descriptor\n");
53 rdesc[84] = rdesc[89] = 0x4d; 53 rdesc[84] = rdesc[89] = 0x4d;
54 rdesc[85] = rdesc[90] = 0x10; 54 rdesc[85] = rdesc[90] = 0x10;
55 } 55 }
56 if ((quirks & LG_RDESC_REL_ABS) && rsize >= 50 && 56 if ((quirks & LG_RDESC_REL_ABS) && *rsize >= 50 &&
57 rdesc[32] == 0x81 && rdesc[33] == 0x06 && 57 rdesc[32] == 0x81 && rdesc[33] == 0x06 &&
58 rdesc[49] == 0x81 && rdesc[50] == 0x06) { 58 rdesc[49] == 0x81 && rdesc[50] == 0x06) {
59 dev_info(&hdev->dev, "fixing up rel/abs in Logitech " 59 dev_info(&hdev->dev, "fixing up rel/abs in Logitech "
60 "report descriptor\n"); 60 "report descriptor\n");
61 rdesc[33] = rdesc[50] = 0x02; 61 rdesc[33] = rdesc[50] = 0x02;
62 } 62 }
63 return rdesc;
63} 64}
64 65
65#define lg_map_key_clear(c) hid_map_usage_clear(hi, usage, bit, max, \ 66#define lg_map_key_clear(c) hid_map_usage_clear(hi, usage, bit, max, \