diff options
-rw-r--r-- | drivers/hid/hid-core.c | 25 | ||||
-rw-r--r-- | drivers/hid/hid-debug.c | 30 | ||||
-rw-r--r-- | include/linux/hid-debug.h | 6 |
3 files changed, 36 insertions, 25 deletions
diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c index aa341d135867..f86dd9708ca5 100644 --- a/drivers/hid/hid-core.c +++ b/drivers/hid/hid-core.c | |||
@@ -1260,8 +1260,6 @@ int hid_input_report(struct hid_device *hid, int type, u8 *data, int size, int i | |||
1260 | struct hid_report_enum *report_enum; | 1260 | struct hid_report_enum *report_enum; |
1261 | struct hid_driver *hdrv; | 1261 | struct hid_driver *hdrv; |
1262 | struct hid_report *report; | 1262 | struct hid_report *report; |
1263 | char *buf; | ||
1264 | unsigned int i; | ||
1265 | int ret = 0; | 1263 | int ret = 0; |
1266 | 1264 | ||
1267 | if (!hid) | 1265 | if (!hid) |
@@ -1284,28 +1282,9 @@ int hid_input_report(struct hid_device *hid, int type, u8 *data, int size, int i | |||
1284 | } | 1282 | } |
1285 | 1283 | ||
1286 | /* Avoid unnecessary overhead if debugfs is disabled */ | 1284 | /* Avoid unnecessary overhead if debugfs is disabled */ |
1287 | if (list_empty(&hid->debug_list)) | 1285 | if (!list_empty(&hid->debug_list)) |
1288 | goto nomem; | 1286 | hid_dump_report(hid, type, data, size); |
1289 | |||
1290 | buf = kmalloc(sizeof(char) * HID_DEBUG_BUFSIZE, GFP_ATOMIC); | ||
1291 | |||
1292 | if (!buf) | ||
1293 | goto nomem; | ||
1294 | |||
1295 | /* dump the report */ | ||
1296 | snprintf(buf, HID_DEBUG_BUFSIZE - 1, | ||
1297 | "\nreport (size %u) (%snumbered) = ", size, report_enum->numbered ? "" : "un"); | ||
1298 | hid_debug_event(hid, buf); | ||
1299 | |||
1300 | for (i = 0; i < size; i++) { | ||
1301 | snprintf(buf, HID_DEBUG_BUFSIZE - 1, | ||
1302 | " %02x", data[i]); | ||
1303 | hid_debug_event(hid, buf); | ||
1304 | } | ||
1305 | hid_debug_event(hid, "\n"); | ||
1306 | kfree(buf); | ||
1307 | 1287 | ||
1308 | nomem: | ||
1309 | report = hid_get_report(report_enum, data); | 1288 | report = hid_get_report(report_enum, data); |
1310 | 1289 | ||
1311 | if (!report) { | 1290 | if (!report) { |
diff --git a/drivers/hid/hid-debug.c b/drivers/hid/hid-debug.c index 933fff0fff1f..094cbcfe1e1a 100644 --- a/drivers/hid/hid-debug.c +++ b/drivers/hid/hid-debug.c | |||
@@ -591,6 +591,36 @@ void hid_debug_event(struct hid_device *hdev, char *buf) | |||
591 | } | 591 | } |
592 | EXPORT_SYMBOL_GPL(hid_debug_event); | 592 | EXPORT_SYMBOL_GPL(hid_debug_event); |
593 | 593 | ||
594 | void hid_dump_report(struct hid_device *hid, int type, u8 *data, | ||
595 | int size) | ||
596 | { | ||
597 | struct hid_report_enum *report_enum; | ||
598 | char *buf; | ||
599 | unsigned int i; | ||
600 | |||
601 | buf = kmalloc(sizeof(char) * HID_DEBUG_BUFSIZE, GFP_ATOMIC); | ||
602 | |||
603 | if (!buf) | ||
604 | return; | ||
605 | |||
606 | report_enum = hid->report_enum + type; | ||
607 | |||
608 | /* dump the report */ | ||
609 | snprintf(buf, HID_DEBUG_BUFSIZE - 1, | ||
610 | "\nreport (size %u) (%snumbered) = ", size, | ||
611 | report_enum->numbered ? "" : "un"); | ||
612 | hid_debug_event(hid, buf); | ||
613 | |||
614 | for (i = 0; i < size; i++) { | ||
615 | snprintf(buf, HID_DEBUG_BUFSIZE - 1, | ||
616 | " %02x", data[i]); | ||
617 | hid_debug_event(hid, buf); | ||
618 | } | ||
619 | hid_debug_event(hid, "\n"); | ||
620 | kfree(buf); | ||
621 | } | ||
622 | EXPORT_SYMBOL_GPL(hid_dump_report); | ||
623 | |||
594 | void hid_dump_input(struct hid_device *hdev, struct hid_usage *usage, __s32 value) | 624 | void hid_dump_input(struct hid_device *hdev, struct hid_usage *usage, __s32 value) |
595 | { | 625 | { |
596 | char *buf; | 626 | char *buf; |
diff --git a/include/linux/hid-debug.h b/include/linux/hid-debug.h index 53744fa1c8b7..8663f216c563 100644 --- a/include/linux/hid-debug.h +++ b/include/linux/hid-debug.h | |||
@@ -22,11 +22,12 @@ | |||
22 | * | 22 | * |
23 | */ | 23 | */ |
24 | 24 | ||
25 | #define HID_DEBUG_BUFSIZE 512 | ||
26 | |||
27 | #ifdef CONFIG_DEBUG_FS | 25 | #ifdef CONFIG_DEBUG_FS |
28 | 26 | ||
27 | #define HID_DEBUG_BUFSIZE 512 | ||
28 | |||
29 | void hid_dump_input(struct hid_device *, struct hid_usage *, __s32); | 29 | void hid_dump_input(struct hid_device *, struct hid_usage *, __s32); |
30 | void hid_dump_report(struct hid_device *, int , u8 *, int); | ||
30 | void hid_dump_device(struct hid_device *, struct seq_file *); | 31 | void hid_dump_device(struct hid_device *, struct seq_file *); |
31 | void hid_dump_field(struct hid_field *, int, struct seq_file *); | 32 | void hid_dump_field(struct hid_field *, int, struct seq_file *); |
32 | char *hid_resolv_usage(unsigned, struct seq_file *); | 33 | char *hid_resolv_usage(unsigned, struct seq_file *); |
@@ -50,6 +51,7 @@ struct hid_debug_list { | |||
50 | #else | 51 | #else |
51 | 52 | ||
52 | #define hid_dump_input(a,b,c) do { } while (0) | 53 | #define hid_dump_input(a,b,c) do { } while (0) |
54 | #define hid_dump_report(a,b,c,d) do { } while (0) | ||
53 | #define hid_dump_device(a,b) do { } while (0) | 55 | #define hid_dump_device(a,b) do { } while (0) |
54 | #define hid_dump_field(a,b,c) do { } while (0) | 56 | #define hid_dump_field(a,b,c) do { } while (0) |
55 | #define hid_resolv_usage(a,b) do { } while (0) | 57 | #define hid_resolv_usage(a,b) do { } while (0) |