diff options
author | Henrik Rydberg <rydberg@euromail.se> | 2012-04-23 06:07:07 -0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2012-05-01 06:54:55 -0400 |
commit | 8215d557e5f3a70e50e07c857d35c250fee62a73 (patch) | |
tree | 1ba7ffa5bddacacc9bff64a049e0ca091d43b65d | |
parent | 4fa3a5837b8427faab9b064b1948795eb77b9f8d (diff) |
HID: Create a common generic driver
Move the hid drivers of the bus drivers to a common generic hid
driver, and make it a proper module. This ought to simplify device
handling moving forward.
Cc: Gustavo Padovan <gustavo@padovan.org>
Signed-off-by: Henrik Rydberg <rydberg@euromail.se>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
-rw-r--r-- | drivers/hid/Kconfig | 12 | ||||
-rw-r--r-- | drivers/hid/Makefile | 2 | ||||
-rw-r--r-- | drivers/hid/hid-generic.c | 53 | ||||
-rw-r--r-- | drivers/hid/usbhid/hid-core.c | 16 | ||||
-rw-r--r-- | net/bluetooth/hidp/core.c | 27 |
5 files changed, 68 insertions, 42 deletions
diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index ffddcba32af6..9a581e1a1903 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig | |||
@@ -60,6 +60,18 @@ source "drivers/hid/usbhid/Kconfig" | |||
60 | menu "Special HID drivers" | 60 | menu "Special HID drivers" |
61 | depends on HID | 61 | depends on HID |
62 | 62 | ||
63 | config HID_GENERIC | ||
64 | tristate "Generic HID driver" | ||
65 | depends on HID | ||
66 | default y | ||
67 | ---help--- | ||
68 | Support for generic HID devices. | ||
69 | |||
70 | To compile this driver as a module, choose M here: the module | ||
71 | will be called hid-generic. | ||
72 | |||
73 | If unsure, say Y. | ||
74 | |||
63 | config HID_A4TECH | 75 | config HID_A4TECH |
64 | tristate "A4 tech mice" if EXPERT | 76 | tristate "A4 tech mice" if EXPERT |
65 | depends on USB_HID | 77 | depends on USB_HID |
diff --git a/drivers/hid/Makefile b/drivers/hid/Makefile index 22f1d16cd79c..a04cffa4784f 100644 --- a/drivers/hid/Makefile +++ b/drivers/hid/Makefile | |||
@@ -9,6 +9,8 @@ endif | |||
9 | 9 | ||
10 | obj-$(CONFIG_HID) += hid.o | 10 | obj-$(CONFIG_HID) += hid.o |
11 | 11 | ||
12 | obj-$(CONFIG_HID_GENERIC) += hid-generic.o | ||
13 | |||
12 | hid-$(CONFIG_HIDRAW) += hidraw.o | 14 | hid-$(CONFIG_HIDRAW) += hidraw.o |
13 | 15 | ||
14 | hid-logitech-y := hid-lg.o | 16 | hid-logitech-y := hid-lg.o |
diff --git a/drivers/hid/hid-generic.c b/drivers/hid/hid-generic.c new file mode 100644 index 000000000000..a8b3148e03a2 --- /dev/null +++ b/drivers/hid/hid-generic.c | |||
@@ -0,0 +1,53 @@ | |||
1 | /* | ||
2 | * HID support for Linux | ||
3 | * | ||
4 | * Copyright (c) 1999 Andreas Gal | ||
5 | * Copyright (c) 2000-2005 Vojtech Pavlik <vojtech@suse.cz> | ||
6 | * Copyright (c) 2005 Michael Haboustak <mike-@cinci.rr.com> for Concept2, Inc | ||
7 | * Copyright (c) 2007-2008 Oliver Neukum | ||
8 | * Copyright (c) 2006-2012 Jiri Kosina | ||
9 | * Copyright (c) 2012 Henrik Rydberg | ||
10 | */ | ||
11 | |||
12 | /* | ||
13 | * This program is free software; you can redistribute it and/or modify it | ||
14 | * under the terms of the GNU General Public License as published by the Free | ||
15 | * Software Foundation; either version 2 of the License, or (at your option) | ||
16 | * any later version. | ||
17 | */ | ||
18 | |||
19 | #include <linux/module.h> | ||
20 | #include <linux/slab.h> | ||
21 | #include <linux/kernel.h> | ||
22 | #include <asm/unaligned.h> | ||
23 | #include <asm/byteorder.h> | ||
24 | |||
25 | #include <linux/hid.h> | ||
26 | |||
27 | static const struct hid_device_id hid_table[] = { | ||
28 | { HID_DEVICE(HID_BUS_ANY, HID_GROUP_GENERIC, HID_ANY_ID, HID_ANY_ID) }, | ||
29 | { } | ||
30 | }; | ||
31 | MODULE_DEVICE_TABLE(hid, hid_table); | ||
32 | |||
33 | static struct hid_driver hid_generic = { | ||
34 | .name = "hid-generic", | ||
35 | .id_table = hid_table, | ||
36 | }; | ||
37 | |||
38 | static int __init hid_init(void) | ||
39 | { | ||
40 | return hid_register_driver(&hid_generic); | ||
41 | } | ||
42 | |||
43 | static void __exit hid_exit(void) | ||
44 | { | ||
45 | hid_unregister_driver(&hid_generic); | ||
46 | } | ||
47 | |||
48 | module_init(hid_init); | ||
49 | module_exit(hid_exit); | ||
50 | |||
51 | MODULE_AUTHOR("Henrik Rydberg"); | ||
52 | MODULE_DESCRIPTION("HID generic driver"); | ||
53 | MODULE_LICENSE("GPL"); | ||
diff --git a/drivers/hid/usbhid/hid-core.c b/drivers/hid/usbhid/hid-core.c index 9abf718318ca..9cba5006b5ed 100644 --- a/drivers/hid/usbhid/hid-core.c +++ b/drivers/hid/usbhid/hid-core.c | |||
@@ -1504,28 +1504,15 @@ static struct usb_driver hid_driver = { | |||
1504 | .supports_autosuspend = 1, | 1504 | .supports_autosuspend = 1, |
1505 | }; | 1505 | }; |
1506 | 1506 | ||
1507 | static const struct hid_device_id hid_usb_table[] = { | ||
1508 | { HID_DEVICE(BUS_USB, HID_GROUP_GENERIC, HID_ANY_ID, HID_ANY_ID) }, | ||
1509 | { } | ||
1510 | }; | ||
1511 | |||
1512 | struct usb_interface *usbhid_find_interface(int minor) | 1507 | struct usb_interface *usbhid_find_interface(int minor) |
1513 | { | 1508 | { |
1514 | return usb_find_interface(&hid_driver, minor); | 1509 | return usb_find_interface(&hid_driver, minor); |
1515 | } | 1510 | } |
1516 | 1511 | ||
1517 | static struct hid_driver hid_usb_driver = { | ||
1518 | .name = "generic-usb", | ||
1519 | .id_table = hid_usb_table, | ||
1520 | }; | ||
1521 | |||
1522 | static int __init hid_init(void) | 1512 | static int __init hid_init(void) |
1523 | { | 1513 | { |
1524 | int retval = -ENOMEM; | 1514 | int retval = -ENOMEM; |
1525 | 1515 | ||
1526 | retval = hid_register_driver(&hid_usb_driver); | ||
1527 | if (retval) | ||
1528 | goto hid_register_fail; | ||
1529 | retval = usbhid_quirks_init(quirks_param); | 1516 | retval = usbhid_quirks_init(quirks_param); |
1530 | if (retval) | 1517 | if (retval) |
1531 | goto usbhid_quirks_init_fail; | 1518 | goto usbhid_quirks_init_fail; |
@@ -1538,8 +1525,6 @@ static int __init hid_init(void) | |||
1538 | usb_register_fail: | 1525 | usb_register_fail: |
1539 | usbhid_quirks_exit(); | 1526 | usbhid_quirks_exit(); |
1540 | usbhid_quirks_init_fail: | 1527 | usbhid_quirks_init_fail: |
1541 | hid_unregister_driver(&hid_usb_driver); | ||
1542 | hid_register_fail: | ||
1543 | return retval; | 1528 | return retval; |
1544 | } | 1529 | } |
1545 | 1530 | ||
@@ -1547,7 +1532,6 @@ static void __exit hid_exit(void) | |||
1547 | { | 1532 | { |
1548 | usb_deregister(&hid_driver); | 1533 | usb_deregister(&hid_driver); |
1549 | usbhid_quirks_exit(); | 1534 | usbhid_quirks_exit(); |
1550 | hid_unregister_driver(&hid_usb_driver); | ||
1551 | } | 1535 | } |
1552 | 1536 | ||
1553 | module_init(hid_init); | 1537 | module_init(hid_init); |
diff --git a/net/bluetooth/hidp/core.c b/net/bluetooth/hidp/core.c index b6fa982e4031..2c20d765b394 100644 --- a/net/bluetooth/hidp/core.c +++ b/net/bluetooth/hidp/core.c | |||
@@ -1195,41 +1195,16 @@ int hidp_get_conninfo(struct hidp_conninfo *ci) | |||
1195 | return err; | 1195 | return err; |
1196 | } | 1196 | } |
1197 | 1197 | ||
1198 | static const struct hid_device_id hidp_table[] = { | ||
1199 | { HID_DEVICE(BUS_BLUETOOTH, HID_GROUP_GENERIC, HID_ANY_ID, HID_ANY_ID) }, | ||
1200 | { } | ||
1201 | }; | ||
1202 | |||
1203 | static struct hid_driver hidp_driver = { | ||
1204 | .name = "generic-bluetooth", | ||
1205 | .id_table = hidp_table, | ||
1206 | }; | ||
1207 | |||
1208 | static int __init hidp_init(void) | 1198 | static int __init hidp_init(void) |
1209 | { | 1199 | { |
1210 | int ret; | ||
1211 | |||
1212 | BT_INFO("HIDP (Human Interface Emulation) ver %s", VERSION); | 1200 | BT_INFO("HIDP (Human Interface Emulation) ver %s", VERSION); |
1213 | 1201 | ||
1214 | ret = hid_register_driver(&hidp_driver); | 1202 | return hidp_init_sockets(); |
1215 | if (ret) | ||
1216 | goto err; | ||
1217 | |||
1218 | ret = hidp_init_sockets(); | ||
1219 | if (ret) | ||
1220 | goto err_drv; | ||
1221 | |||
1222 | return 0; | ||
1223 | err_drv: | ||
1224 | hid_unregister_driver(&hidp_driver); | ||
1225 | err: | ||
1226 | return ret; | ||
1227 | } | 1203 | } |
1228 | 1204 | ||
1229 | static void __exit hidp_exit(void) | 1205 | static void __exit hidp_exit(void) |
1230 | { | 1206 | { |
1231 | hidp_cleanup_sockets(); | 1207 | hidp_cleanup_sockets(); |
1232 | hid_unregister_driver(&hidp_driver); | ||
1233 | } | 1208 | } |
1234 | 1209 | ||
1235 | module_init(hidp_init); | 1210 | module_init(hidp_init); |