diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/hid.h | 104 |
1 files changed, 96 insertions, 8 deletions
diff --git a/include/linux/hid.h b/include/linux/hid.h index b7a17762a0b2..c4bea0eda85b 100644 --- a/include/linux/hid.h +++ b/include/linux/hid.h | |||
@@ -418,6 +418,8 @@ struct hid_control_fifo { | |||
418 | #define HID_CLAIMED_HIDDEV 2 | 418 | #define HID_CLAIMED_HIDDEV 2 |
419 | #define HID_CLAIMED_HIDRAW 4 | 419 | #define HID_CLAIMED_HIDRAW 4 |
420 | 420 | ||
421 | #define HID_STAT_ADDED 1 | ||
422 | |||
421 | #define HID_CTRL_RUNNING 1 | 423 | #define HID_CTRL_RUNNING 1 |
422 | #define HID_OUT_RUNNING 2 | 424 | #define HID_OUT_RUNNING 2 |
423 | #define HID_IN_RUNNING 3 | 425 | #define HID_IN_RUNNING 3 |
@@ -432,22 +434,26 @@ struct hid_input { | |||
432 | struct input_dev *input; | 434 | struct input_dev *input; |
433 | }; | 435 | }; |
434 | 436 | ||
437 | struct hid_driver; | ||
438 | |||
435 | struct hid_device { /* device report descriptor */ | 439 | struct hid_device { /* device report descriptor */ |
436 | __u8 *rdesc; | 440 | __u8 *rdesc; |
437 | unsigned rsize; | 441 | unsigned rsize; |
438 | struct hid_collection *collection; /* List of HID collections */ | 442 | struct hid_collection *collection; /* List of HID collections */ |
439 | unsigned collection_size; /* Number of allocated hid_collections */ | 443 | unsigned collection_size; /* Number of allocated hid_collections */ |
440 | unsigned maxcollection; /* Number of parsed collections */ | 444 | unsigned maxcollection; /* Number of parsed collections */ |
441 | unsigned maxapplication; /* Number of applications */ | 445 | unsigned maxapplication; /* Number of applications */ |
442 | unsigned short bus; /* BUS ID */ | 446 | __u16 bus; /* BUS ID */ |
443 | unsigned short vendor; /* Vendor ID */ | 447 | __u32 vendor; /* Vendor ID */ |
444 | unsigned short product; /* Product ID */ | 448 | __u32 product; /* Product ID */ |
445 | unsigned version; /* HID version */ | 449 | __u32 version; /* HID version */ |
446 | unsigned country; /* HID country */ | 450 | unsigned country; /* HID country */ |
447 | struct hid_report_enum report_enum[HID_REPORT_TYPES]; | 451 | struct hid_report_enum report_enum[HID_REPORT_TYPES]; |
448 | 452 | ||
449 | struct device *dev; /* device */ | 453 | struct device dev; /* device */ |
454 | struct hid_driver *driver; | ||
450 | 455 | ||
456 | unsigned int status; /* see STAT flags above */ | ||
451 | unsigned claimed; /* Claimed by hidinput, hiddev? */ | 457 | unsigned claimed; /* Claimed by hidinput, hiddev? */ |
452 | unsigned quirks; /* Various quirks the device can pull on us */ | 458 | unsigned quirks; /* Various quirks the device can pull on us */ |
453 | 459 | ||
@@ -483,6 +489,16 @@ struct hid_device { /* device report descriptor */ | |||
483 | #endif | 489 | #endif |
484 | }; | 490 | }; |
485 | 491 | ||
492 | static inline void *hid_get_drvdata(struct hid_device *hdev) | ||
493 | { | ||
494 | return dev_get_drvdata(&hdev->dev); | ||
495 | } | ||
496 | |||
497 | static inline void hid_set_drvdata(struct hid_device *hdev, void *data) | ||
498 | { | ||
499 | dev_set_drvdata(&hdev->dev, data); | ||
500 | } | ||
501 | |||
486 | #define HID_GLOBAL_STACK_SIZE 4 | 502 | #define HID_GLOBAL_STACK_SIZE 4 |
487 | #define HID_COLLECTION_STACK_SIZE 4 | 503 | #define HID_COLLECTION_STACK_SIZE 4 |
488 | 504 | ||
@@ -511,6 +527,61 @@ struct hid_descriptor { | |||
511 | struct hid_class_descriptor desc[1]; | 527 | struct hid_class_descriptor desc[1]; |
512 | } __attribute__ ((packed)); | 528 | } __attribute__ ((packed)); |
513 | 529 | ||
530 | #define HID_DEVICE(b, ven, prod) \ | ||
531 | .bus = (b), \ | ||
532 | .vendor = (ven), .product = (prod) | ||
533 | |||
534 | #define HID_USB_DEVICE(ven, prod) HID_DEVICE(BUS_USB, ven, prod) | ||
535 | #define HID_BLUETOOTH_DEVICE(ven, prod) HID_DEVICE(BUS_BLUETOOTH, ven, prod) | ||
536 | |||
537 | #define HID_REPORT_ID(rep) \ | ||
538 | .report_type = (rep) | ||
539 | #define HID_USAGE_ID(uhid, utype, ucode) \ | ||
540 | .usage_hid = (uhid), .usage_type = (utype), .usage_code = (ucode) | ||
541 | /* we don't want to catch types and codes equal to 0 */ | ||
542 | #define HID_TERMINATOR (HID_ANY_ID - 1) | ||
543 | |||
544 | struct hid_report_id { | ||
545 | __u32 report_type; | ||
546 | }; | ||
547 | struct hid_usage_id { | ||
548 | __u32 usage_hid; | ||
549 | __u32 usage_type; | ||
550 | __u32 usage_code; | ||
551 | }; | ||
552 | |||
553 | /** | ||
554 | * struct hid_driver | ||
555 | * @name: driver name (e.g. "Footech_bar-wheel") | ||
556 | * @id_table: which devices is this driver for (must be non-NULL for probe | ||
557 | * to be called) | ||
558 | * @probe: new device inserted | ||
559 | * @remove: device removed (NULL if not a hot-plug capable driver) | ||
560 | * @report_table: on which reports to call raw_event (NULL means all) | ||
561 | * @raw_event: if report in report_table, this hook is called (NULL means nop) | ||
562 | * @usage_table: on which events to call event (NULL means all) | ||
563 | * @event: if usage in usage_table, this hook is called (NULL means nop) | ||
564 | * | ||
565 | * raw_event and event should return 0 on no action performed, 1 when no | ||
566 | * further processing should be done and negative on error | ||
567 | */ | ||
568 | struct hid_driver { | ||
569 | char *name; | ||
570 | const struct hid_device_id *id_table; | ||
571 | |||
572 | int (*probe)(struct hid_device *dev, const struct hid_device_id *id); | ||
573 | void (*remove)(struct hid_device *dev); | ||
574 | |||
575 | const struct hid_report_id *report_table; | ||
576 | int (*raw_event)(struct hid_device *hdev, struct hid_report *report, | ||
577 | u8 *data, int size); | ||
578 | const struct hid_usage_id *usage_table; | ||
579 | int (*event)(struct hid_device *hdev, struct hid_field *field, | ||
580 | struct hid_usage *usage, __s32 value); | ||
581 | /* private: */ | ||
582 | struct device_driver driver; | ||
583 | }; | ||
584 | |||
514 | /* Applications from HID Usage Tables 4/8/99 Version 1.1 */ | 585 | /* Applications from HID Usage Tables 4/8/99 Version 1.1 */ |
515 | /* We ignore a few input applications that are not widely used */ | 586 | /* We ignore a few input applications that are not widely used */ |
516 | #define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || (a == 0x00010080) || (a == 0x000c0001) || (a == 0x000d0002)) | 587 | #define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || (a == 0x00010080) || (a == 0x000c0001) || (a == 0x000d0002)) |
@@ -521,6 +592,17 @@ struct hid_descriptor { | |||
521 | extern int hid_debug; | 592 | extern int hid_debug; |
522 | #endif | 593 | #endif |
523 | 594 | ||
595 | extern int hid_add_device(struct hid_device *); | ||
596 | extern void hid_destroy_device(struct hid_device *); | ||
597 | |||
598 | extern int __must_check __hid_register_driver(struct hid_driver *, | ||
599 | struct module *, const char *mod_name); | ||
600 | static inline int __must_check hid_register_driver(struct hid_driver *driver) | ||
601 | { | ||
602 | return __hid_register_driver(driver, THIS_MODULE, KBUILD_MODNAME); | ||
603 | } | ||
604 | extern void hid_unregister_driver(struct hid_driver *); | ||
605 | |||
524 | extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); | 606 | extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); |
525 | extern void hidinput_report_event(struct hid_device *hid, struct hid_report *report); | 607 | extern void hidinput_report_event(struct hid_device *hid, struct hid_report *report); |
526 | extern int hidinput_connect(struct hid_device *); | 608 | extern int hidinput_connect(struct hid_device *); |
@@ -533,8 +615,14 @@ int hidinput_mapping_quirks(struct hid_usage *, struct input_dev *, unsigned lon | |||
533 | int hidinput_event_quirks(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); | 615 | int hidinput_event_quirks(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); |
534 | int hidinput_apple_event(struct hid_device *, struct input_dev *, struct hid_usage *, __s32); | 616 | int hidinput_apple_event(struct hid_device *, struct input_dev *, struct hid_usage *, __s32); |
535 | void hid_output_report(struct hid_report *report, __u8 *data); | 617 | void hid_output_report(struct hid_report *report, __u8 *data); |
536 | void hid_free_device(struct hid_device *device); | 618 | struct hid_device *hid_allocate_device(void); |
537 | struct hid_device *hid_parse_report(__u8 *start, unsigned size); | 619 | int hid_parse_report(struct hid_device *hid, __u8 *start, unsigned size); |
620 | |||
621 | void hid_report_raw_event(struct hid_device *hid, int type, u8 *data, int size, | ||
622 | int interrupt); | ||
623 | |||
624 | extern int hid_generic_init(void); | ||
625 | extern void hid_generic_exit(void); | ||
538 | 626 | ||
539 | /* HID quirks API */ | 627 | /* HID quirks API */ |
540 | u32 usbhid_lookup_quirk(const u16 idVendor, const u16 idProduct); | 628 | u32 usbhid_lookup_quirk(const u16 idVendor, const u16 idProduct); |