diff options
author | Nikolai Kondrashov <spbnick@gmail.com> | 2010-08-06 15:03:06 -0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2010-08-09 13:52:42 -0400 |
commit | 73e4008ddddc84d5f2499c17012b340a0dae153e (patch) | |
tree | d3adfa8c5792e71c21cb7a9cd18517cce9c92685 /drivers/hid/hid-lg.c | |
parent | 3cfc2c42c1cbc8e238bb9c0612c0df4565e3a8b4 (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.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/hid/hid-lg.c b/drivers/hid/hid-lg.c index f6433d8050a9..68c0b68856c7 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 | */ |
44 | static void lg_report_fixup(struct hid_device *hdev, __u8 *rdesc, | 44 | static __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, \ |