diff options
author | Jiri Kosina <jkosina@suse.cz> | 2006-12-08 12:41:10 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2006-12-08 13:43:15 -0500 |
commit | aa938f7974b82cfd9ee955031987344f332b7c77 (patch) | |
tree | 21198b8aa8a4c3be76def4b57968dae816753846 | |
parent | 4916b3a57fc94664677d439b911b8aaf86c7ec23 (diff) |
[PATCH] Generic HID layer - hiddev
- hiddev is USB-only (agreed with Marcel Holtmann that Bluetooth currently
doesn't need it, and future planned interface (rawhid) will be more flexible
and usable)
- both HID and USB-hid can be now compiled as modules (wasn't possible before
hiddev was fully separated from generic HID layer)
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r-- | drivers/hid/hid-core.c | 6 | ||||
-rw-r--r-- | drivers/usb/input/hid-core.c | 3 | ||||
-rw-r--r-- | include/linux/hid.h | 8 |
3 files changed, 11 insertions, 6 deletions
diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c index 8474a7923322..1dd9e4f0df1e 100644 --- a/drivers/hid/hid-core.c +++ b/drivers/hid/hid-core.c | |||
@@ -819,8 +819,8 @@ static void hid_process_event(struct hid_device *hid, struct hid_field *field, s | |||
819 | hid_dump_input(usage, value); | 819 | hid_dump_input(usage, value); |
820 | if (hid->claimed & HID_CLAIMED_INPUT) | 820 | if (hid->claimed & HID_CLAIMED_INPUT) |
821 | hidinput_hid_event(hid, field, usage, value); | 821 | hidinput_hid_event(hid, field, usage, value); |
822 | if (hid->claimed & HID_CLAIMED_HIDDEV && interrupt) | 822 | if (hid->claimed & HID_CLAIMED_HIDDEV && interrupt && hid->hiddev_hid_event) |
823 | hiddev_hid_event(hid, field, usage, value); | 823 | hid->hiddev_hid_event(hid, field, usage, value); |
824 | } | 824 | } |
825 | 825 | ||
826 | /* | 826 | /* |
@@ -940,3 +940,5 @@ int hid_set_field(struct hid_field *field, unsigned offset, __s32 value) | |||
940 | } | 940 | } |
941 | EXPORT_SYMBOL_GPL(hid_set_field); | 941 | EXPORT_SYMBOL_GPL(hid_set_field); |
942 | 942 | ||
943 | MODULE_LICENSE(DRIVER_LICENSE); | ||
944 | |||
diff --git a/drivers/usb/input/hid-core.c b/drivers/usb/input/hid-core.c index 0991c4b751a6..4fc828041d0f 100644 --- a/drivers/usb/input/hid-core.c +++ b/drivers/usb/input/hid-core.c | |||
@@ -1284,6 +1284,9 @@ static struct hid_device *usb_hid_configure(struct usb_interface *intf) | |||
1284 | hid->hidinput_input_event = usb_hidinput_input_event; | 1284 | hid->hidinput_input_event = usb_hidinput_input_event; |
1285 | hid->hidinput_open = hidinput_open; | 1285 | hid->hidinput_open = hidinput_open; |
1286 | hid->hidinput_close = hidinput_close; | 1286 | hid->hidinput_close = hidinput_close; |
1287 | #ifdef CONFIG_USB_HIDDEV | ||
1288 | hid->hiddev_hid_event = hiddev_hid_event; | ||
1289 | #endif | ||
1287 | 1290 | ||
1288 | return hid; | 1291 | return hid; |
1289 | 1292 | ||
diff --git a/include/linux/hid.h b/include/linux/hid.h index fc6f74228da3..5a969a137b85 100644 --- a/include/linux/hid.h +++ b/include/linux/hid.h | |||
@@ -433,6 +433,10 @@ struct hid_device { /* device report descriptor */ | |||
433 | int (*hidinput_open) (struct input_dev *); | 433 | int (*hidinput_open) (struct input_dev *); |
434 | void (*hidinput_close) (struct input_dev *); | 434 | void (*hidinput_close) (struct input_dev *); |
435 | 435 | ||
436 | /* hiddev event handler */ | ||
437 | void (*hiddev_hid_event) (struct hid_device *, struct hid_field *field, | ||
438 | struct hid_usage *, __s32); | ||
439 | |||
436 | #ifdef CONFIG_USB_HIDINPUT_POWERBOOK | 440 | #ifdef CONFIG_USB_HIDINPUT_POWERBOOK |
437 | unsigned long pb_pressed_fn[NBITS(KEY_MAX)]; | 441 | unsigned long pb_pressed_fn[NBITS(KEY_MAX)]; |
438 | unsigned long pb_pressed_numlock[NBITS(KEY_MAX)]; | 442 | unsigned long pb_pressed_numlock[NBITS(KEY_MAX)]; |
@@ -477,13 +481,9 @@ struct hid_descriptor { | |||
477 | #define resolv_event(a,b) do { } while (0) | 481 | #define resolv_event(a,b) do { } while (0) |
478 | #endif | 482 | #endif |
479 | 483 | ||
480 | #ifdef CONFIG_HID | ||
481 | /* Applications from HID Usage Tables 4/8/99 Version 1.1 */ | 484 | /* Applications from HID Usage Tables 4/8/99 Version 1.1 */ |
482 | /* We ignore a few input applications that are not widely used */ | 485 | /* We ignore a few input applications that are not widely used */ |
483 | #define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || (a == 0x00010080) || (a == 0x000c0001)) | 486 | #define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || (a == 0x00010080) || (a == 0x000c0001)) |
484 | #else | ||
485 | #define IS_INPUT_APPLICATION(a) (0) | ||
486 | #endif | ||
487 | 487 | ||
488 | /* HID core API */ | 488 | /* HID core API */ |
489 | extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); | 489 | extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); |