usbd_hid.c 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * Copyright (c) 2022, sakumisu
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include "usbd_core.h"
  7. #include "usbd_hid.h"
  8. static int hid_class_interface_request_handler(uint8_t busid, struct usb_setup_packet *setup, uint8_t **data, uint32_t *len)
  9. {
  10. USB_LOG_DBG("HID Class request: "
  11. "bRequest 0x%02x\r\n",
  12. setup->bRequest);
  13. uint8_t intf_num = LO_BYTE(setup->wIndex);
  14. switch (setup->bRequest) {
  15. case HID_REQUEST_GET_REPORT:
  16. /* report id ,report type */
  17. usbd_hid_get_report(busid, intf_num, LO_BYTE(setup->wValue), HI_BYTE(setup->wValue), data, len);
  18. break;
  19. case HID_REQUEST_GET_IDLE:
  20. (*data)[0] = usbd_hid_get_idle(busid, intf_num, LO_BYTE(setup->wValue));
  21. *len = 1;
  22. break;
  23. case HID_REQUEST_GET_PROTOCOL:
  24. (*data)[0] = usbd_hid_get_protocol(busid, intf_num);
  25. *len = 1;
  26. break;
  27. case HID_REQUEST_SET_REPORT:
  28. /* report id ,report type, report, report len */
  29. usbd_hid_set_report(busid, intf_num, LO_BYTE(setup->wValue), HI_BYTE(setup->wValue), *data, *len);
  30. break;
  31. case HID_REQUEST_SET_IDLE:
  32. /* report id, duration */
  33. usbd_hid_set_idle(busid, intf_num, LO_BYTE(setup->wValue), HI_BYTE(setup->wValue));
  34. break;
  35. case HID_REQUEST_SET_PROTOCOL:
  36. /* protocol */
  37. usbd_hid_set_protocol(busid, intf_num, LO_BYTE(setup->wValue));
  38. break;
  39. default:
  40. USB_LOG_WRN("Unhandled HID Class bRequest 0x%02x\r\n", setup->bRequest);
  41. return -1;
  42. }
  43. return 0;
  44. }
  45. struct usbd_interface *usbd_hid_init_intf(uint8_t busid, struct usbd_interface *intf, const uint8_t *desc, uint32_t desc_len)
  46. {
  47. intf->class_interface_handler = hid_class_interface_request_handler;
  48. intf->class_endpoint_handler = NULL;
  49. intf->vendor_handler = NULL;
  50. intf->notify_handler = NULL;
  51. intf->hid_report_descriptor = desc;
  52. intf->hid_report_descriptor_len = desc_len;
  53. return intf;
  54. }
  55. __WEAK void usbd_hid_get_report(uint8_t busid, uint8_t intf, uint8_t report_id, uint8_t report_type, uint8_t **data, uint32_t *len)
  56. {
  57. (*data[0]) = 0;
  58. *len = 1;
  59. }
  60. __WEAK uint8_t usbd_hid_get_idle(uint8_t busid, uint8_t intf, uint8_t report_id)
  61. {
  62. return 0;
  63. }
  64. __WEAK uint8_t usbd_hid_get_protocol(uint8_t busid, uint8_t intf)
  65. {
  66. return 0;
  67. }
  68. __WEAK void usbd_hid_set_report(uint8_t busid, uint8_t intf, uint8_t report_id, uint8_t report_type, uint8_t *report, uint32_t report_len)
  69. {
  70. }
  71. __WEAK void usbd_hid_set_idle(uint8_t busid, uint8_t intf, uint8_t report_id, uint8_t duration)
  72. {
  73. }
  74. __WEAK void usbd_hid_set_protocol(uint8_t busid, uint8_t intf, uint8_t protocol)
  75. {
  76. }