furi_hal_usb.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #pragma once
  2. #include "usb.h"
  3. typedef struct FuriHalUsbInterface FuriHalUsbInterface;
  4. struct FuriHalUsbInterface {
  5. void (*init)(usbd_device* dev, FuriHalUsbInterface* intf, void* ctx);
  6. void (*deinit)(usbd_device* dev);
  7. void (*wakeup)(usbd_device* dev);
  8. void (*suspend)(usbd_device* dev);
  9. struct usb_device_descriptor* dev_descr;
  10. void* str_manuf_descr;
  11. void* str_prod_descr;
  12. void* str_serial_descr;
  13. void* cfg_descr;
  14. };
  15. /** USB device interface modes */
  16. extern FuriHalUsbInterface usb_cdc_single;
  17. extern FuriHalUsbInterface usb_cdc_dual;
  18. extern FuriHalUsbInterface usb_hid;
  19. extern FuriHalUsbInterface usb_hid_u2f;
  20. typedef enum {
  21. FuriHalUsbStateEventReset,
  22. FuriHalUsbStateEventWakeup,
  23. FuriHalUsbStateEventSuspend,
  24. FuriHalUsbStateEventDescriptorRequest,
  25. } FuriHalUsbStateEvent;
  26. typedef void (*FuriHalUsbStateCallback)(FuriHalUsbStateEvent state, void* context);
  27. /** USB device low-level initialization
  28. */
  29. void furi_hal_usb_init();
  30. /** Set USB device configuration
  31. *
  32. * @param mode new USB device mode
  33. * @param ctx context passed to device mode init function
  34. * @return true - mode switch started, false - mode switch is locked
  35. */
  36. bool furi_hal_usb_set_config(FuriHalUsbInterface* new_if, void* ctx);
  37. /** Get USB device configuration
  38. *
  39. * @return current USB device mode
  40. */
  41. FuriHalUsbInterface* furi_hal_usb_get_config();
  42. /** Lock USB device mode switch
  43. */
  44. void furi_hal_usb_lock();
  45. /** Unlock USB device mode switch
  46. */
  47. void furi_hal_usb_unlock();
  48. /** Check if USB device mode switch locked
  49. *
  50. * @return lock state
  51. */
  52. bool furi_hal_usb_is_locked();
  53. /** Disable USB device
  54. */
  55. void furi_hal_usb_disable();
  56. /** Enable USB device
  57. */
  58. void furi_hal_usb_enable();
  59. /** Set USB state callback
  60. */
  61. void furi_hal_usb_set_state_callback(FuriHalUsbStateCallback cb, void* ctx);
  62. /** Restart USB device
  63. */
  64. void furi_hal_usb_reinit();