diff options
author | Henrik Rydberg <rydberg@euromail.se> | 2012-04-23 06:07:05 -0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2012-05-01 06:54:55 -0400 |
commit | 070748ed0b52399858a5967026a452bbb903a64c (patch) | |
tree | 9b07b8739db5aa7b9ad31390b394332c10494436 | |
parent | 7431fb767d896b7f0048039f2e17707ea057d35a (diff) |
HID: Create a generic device group
Devices that do not have a special driver are handled by the generic
driver. This patch does the same thing using device groups; Instead of
forcing a particular driver, the appropriate driver is picked up by
udev. As a consequence, one can now move a device from generic to
specific handling by a simple rebind. By adding a new device id to the
generic driver, the same thing can be done in reverse.
Signed-off-by: Henrik Rydberg <rydberg@euromail.se>
Acked-by: Benjamin Tissoires <benjamin.tissoires@gmail.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
-rw-r--r-- | drivers/hid/hid-core.c | 9 | ||||
-rw-r--r-- | drivers/hid/usbhid/hid-core.c | 2 | ||||
-rw-r--r-- | include/linux/hid.h | 12 | ||||
-rw-r--r-- | net/bluetooth/hidp/core.c | 2 |
4 files changed, 9 insertions, 16 deletions
diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c index 20daee56d325..cb5a10337541 100644 --- a/drivers/hid/hid-core.c +++ b/drivers/hid/hid-core.c | |||
@@ -1800,14 +1800,7 @@ static int hid_bus_match(struct device *dev, struct device_driver *drv) | |||
1800 | !strncmp(hdrv->name, "hid-multitouch", 14)) | 1800 | !strncmp(hdrv->name, "hid-multitouch", 14)) |
1801 | return 1; | 1801 | return 1; |
1802 | 1802 | ||
1803 | if (!hid_match_device(hdev, hdrv)) | 1803 | return hid_match_device(hdev, hdrv) != NULL; |
1804 | return 0; | ||
1805 | |||
1806 | /* generic wants all that don't have specialized driver */ | ||
1807 | if (!strncmp(hdrv->name, "generic-", 8) && !hid_ignore_special_drivers) | ||
1808 | return !hid_match_id(hdev, hid_have_special_driver); | ||
1809 | |||
1810 | return 1; | ||
1811 | } | 1804 | } |
1812 | 1805 | ||
1813 | static int hid_device_probe(struct device *dev) | 1806 | static int hid_device_probe(struct device *dev) |
diff --git a/drivers/hid/usbhid/hid-core.c b/drivers/hid/usbhid/hid-core.c index 5bf91dbad59d..9abf718318ca 100644 --- a/drivers/hid/usbhid/hid-core.c +++ b/drivers/hid/usbhid/hid-core.c | |||
@@ -1505,7 +1505,7 @@ static struct usb_driver hid_driver = { | |||
1505 | }; | 1505 | }; |
1506 | 1506 | ||
1507 | static const struct hid_device_id hid_usb_table[] = { | 1507 | static const struct hid_device_id hid_usb_table[] = { |
1508 | { HID_USB_DEVICE(HID_ANY_ID, HID_ANY_ID) }, | 1508 | { HID_DEVICE(BUS_USB, HID_GROUP_GENERIC, HID_ANY_ID, HID_ANY_ID) }, |
1509 | { } | 1509 | { } |
1510 | }; | 1510 | }; |
1511 | 1511 | ||
diff --git a/include/linux/hid.h b/include/linux/hid.h index f45d33d0c121..dd694fb0c284 100644 --- a/include/linux/hid.h +++ b/include/linux/hid.h | |||
@@ -586,12 +586,12 @@ struct hid_descriptor { | |||
586 | struct hid_class_descriptor desc[1]; | 586 | struct hid_class_descriptor desc[1]; |
587 | } __attribute__ ((packed)); | 587 | } __attribute__ ((packed)); |
588 | 588 | ||
589 | #define HID_DEVICE(b, ven, prod) \ | 589 | #define HID_DEVICE(b, g, ven, prod) \ |
590 | .bus = (b), \ | 590 | .bus = (b), .group = (g), .vendor = (ven), .product = (prod) |
591 | .vendor = (ven), .product = (prod) | 591 | #define HID_USB_DEVICE(ven, prod) \ |
592 | 592 | .bus = BUS_USB, .vendor = (ven), .product = (prod) | |
593 | #define HID_USB_DEVICE(ven, prod) HID_DEVICE(BUS_USB, ven, prod) | 593 | #define HID_BLUETOOTH_DEVICE(ven, prod) \ |
594 | #define HID_BLUETOOTH_DEVICE(ven, prod) HID_DEVICE(BUS_BLUETOOTH, ven, prod) | 594 | .bus = BUS_BLUETOOTH, .vendor = (ven), .product = (prod) |
595 | 595 | ||
596 | #define HID_REPORT_ID(rep) \ | 596 | #define HID_REPORT_ID(rep) \ |
597 | .report_type = (rep) | 597 | .report_type = (rep) |
diff --git a/net/bluetooth/hidp/core.c b/net/bluetooth/hidp/core.c index d478be11d562..b6fa982e4031 100644 --- a/net/bluetooth/hidp/core.c +++ b/net/bluetooth/hidp/core.c | |||
@@ -1196,7 +1196,7 @@ int hidp_get_conninfo(struct hidp_conninfo *ci) | |||
1196 | } | 1196 | } |
1197 | 1197 | ||
1198 | static const struct hid_device_id hidp_table[] = { | 1198 | static const struct hid_device_id hidp_table[] = { |
1199 | { HID_BLUETOOTH_DEVICE(HID_ANY_ID, HID_ANY_ID) }, | 1199 | { HID_DEVICE(BUS_BLUETOOTH, HID_GROUP_GENERIC, HID_ANY_ID, HID_ANY_ID) }, |
1200 | { } | 1200 | { } |
1201 | }; | 1201 | }; |
1202 | 1202 | ||