furi_hal_usb_hid.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. #pragma once
  2. #include "hid_usage_desktop.h"
  3. #include "hid_usage_button.h"
  4. #include "hid_usage_keyboard.h"
  5. #include "hid_usage_consumer.h"
  6. #include "hid_usage_led.h"
  7. #ifdef __cplusplus
  8. extern "C" {
  9. #endif
  10. /** Max number of simultaneously pressed keys (keyboard) */
  11. #define HID_KB_MAX_KEYS 6
  12. /** Max number of simultaneously pressed keys (consumer control) */
  13. #define HID_CONSUMER_MAX_KEYS 2
  14. #define HID_KEYBOARD_NONE 0x00
  15. /** HID keyboard modifier keys */
  16. enum HidKeyboardMods {
  17. KEY_MOD_LEFT_CTRL = (1 << 8),
  18. KEY_MOD_LEFT_SHIFT = (1 << 9),
  19. KEY_MOD_LEFT_ALT = (1 << 10),
  20. KEY_MOD_LEFT_GUI = (1 << 11),
  21. KEY_MOD_RIGHT_CTRL = (1 << 12),
  22. KEY_MOD_RIGHT_SHIFT = (1 << 13),
  23. KEY_MOD_RIGHT_ALT = (1 << 14),
  24. KEY_MOD_RIGHT_GUI = (1 << 15),
  25. };
  26. /** ASCII to keycode conversion table */
  27. static const uint16_t hid_asciimap[] = {
  28. HID_KEYBOARD_NONE, // NUL
  29. HID_KEYBOARD_NONE, // SOH
  30. HID_KEYBOARD_NONE, // STX
  31. HID_KEYBOARD_NONE, // ETX
  32. HID_KEYBOARD_NONE, // EOT
  33. HID_KEYBOARD_NONE, // ENQ
  34. HID_KEYBOARD_NONE, // ACK
  35. HID_KEYBOARD_NONE, // BEL
  36. HID_KEYBOARD_DELETE, // BS Backspace
  37. HID_KEYBOARD_TAB, // TAB Tab
  38. HID_KEYBOARD_RETURN, // LF Enter
  39. HID_KEYBOARD_NONE, // VT
  40. HID_KEYBOARD_NONE, // FF
  41. HID_KEYBOARD_NONE, // CR
  42. HID_KEYBOARD_NONE, // SO
  43. HID_KEYBOARD_NONE, // SI
  44. HID_KEYBOARD_NONE, // DEL
  45. HID_KEYBOARD_NONE, // DC1
  46. HID_KEYBOARD_NONE, // DC2
  47. HID_KEYBOARD_NONE, // DC3
  48. HID_KEYBOARD_NONE, // DC4
  49. HID_KEYBOARD_NONE, // NAK
  50. HID_KEYBOARD_NONE, // SYN
  51. HID_KEYBOARD_NONE, // ETB
  52. HID_KEYBOARD_NONE, // CAN
  53. HID_KEYBOARD_NONE, // EM
  54. HID_KEYBOARD_NONE, // SUB
  55. HID_KEYBOARD_NONE, // ESC
  56. HID_KEYBOARD_NONE, // FS
  57. HID_KEYBOARD_NONE, // GS
  58. HID_KEYBOARD_NONE, // RS
  59. HID_KEYBOARD_NONE, // US
  60. HID_KEYBOARD_SPACEBAR, // ' ' Space
  61. HID_KEYBOARD_1 | KEY_MOD_LEFT_SHIFT, // !
  62. HID_KEYBOARD_APOSTROPHE | KEY_MOD_LEFT_SHIFT, // "
  63. HID_KEYBOARD_3 | KEY_MOD_LEFT_SHIFT, // #
  64. HID_KEYBOARD_4 | KEY_MOD_LEFT_SHIFT, // $
  65. HID_KEYBOARD_5 | KEY_MOD_LEFT_SHIFT, // %
  66. HID_KEYBOARD_7 | KEY_MOD_LEFT_SHIFT, // &
  67. HID_KEYBOARD_APOSTROPHE, // '
  68. HID_KEYBOARD_9 | KEY_MOD_LEFT_SHIFT, // (
  69. HID_KEYBOARD_0 | KEY_MOD_LEFT_SHIFT, // )
  70. HID_KEYBOARD_8 | KEY_MOD_LEFT_SHIFT, // *
  71. HID_KEYBOARD_EQUAL_SIGN | KEY_MOD_LEFT_SHIFT, // +
  72. HID_KEYBOARD_COMMA, // ,
  73. HID_KEYBOARD_MINUS, // -
  74. HID_KEYBOARD_DOT, // .
  75. HID_KEYBOARD_SLASH, // /
  76. HID_KEYBOARD_0, // 0
  77. HID_KEYBOARD_1, // 1
  78. HID_KEYBOARD_2, // 2
  79. HID_KEYBOARD_3, // 3
  80. HID_KEYBOARD_4, // 4
  81. HID_KEYBOARD_5, // 5
  82. HID_KEYBOARD_6, // 6
  83. HID_KEYBOARD_7, // 7
  84. HID_KEYBOARD_8, // 8
  85. HID_KEYBOARD_9, // 9
  86. HID_KEYBOARD_SEMICOLON | KEY_MOD_LEFT_SHIFT, // :
  87. HID_KEYBOARD_SEMICOLON, // ;
  88. HID_KEYBOARD_COMMA | KEY_MOD_LEFT_SHIFT, // <
  89. HID_KEYBOARD_EQUAL_SIGN, // =
  90. HID_KEYBOARD_DOT | KEY_MOD_LEFT_SHIFT, // >
  91. HID_KEYBOARD_SLASH | KEY_MOD_LEFT_SHIFT, // ?
  92. HID_KEYBOARD_2 | KEY_MOD_LEFT_SHIFT, // @
  93. HID_KEYBOARD_A | KEY_MOD_LEFT_SHIFT, // A
  94. HID_KEYBOARD_B | KEY_MOD_LEFT_SHIFT, // B
  95. HID_KEYBOARD_C | KEY_MOD_LEFT_SHIFT, // C
  96. HID_KEYBOARD_D | KEY_MOD_LEFT_SHIFT, // D
  97. HID_KEYBOARD_E | KEY_MOD_LEFT_SHIFT, // E
  98. HID_KEYBOARD_F | KEY_MOD_LEFT_SHIFT, // F
  99. HID_KEYBOARD_G | KEY_MOD_LEFT_SHIFT, // G
  100. HID_KEYBOARD_H | KEY_MOD_LEFT_SHIFT, // H
  101. HID_KEYBOARD_I | KEY_MOD_LEFT_SHIFT, // I
  102. HID_KEYBOARD_J | KEY_MOD_LEFT_SHIFT, // J
  103. HID_KEYBOARD_K | KEY_MOD_LEFT_SHIFT, // K
  104. HID_KEYBOARD_L | KEY_MOD_LEFT_SHIFT, // L
  105. HID_KEYBOARD_M | KEY_MOD_LEFT_SHIFT, // M
  106. HID_KEYBOARD_N | KEY_MOD_LEFT_SHIFT, // N
  107. HID_KEYBOARD_O | KEY_MOD_LEFT_SHIFT, // O
  108. HID_KEYBOARD_P | KEY_MOD_LEFT_SHIFT, // P
  109. HID_KEYBOARD_Q | KEY_MOD_LEFT_SHIFT, // Q
  110. HID_KEYBOARD_R | KEY_MOD_LEFT_SHIFT, // R
  111. HID_KEYBOARD_S | KEY_MOD_LEFT_SHIFT, // S
  112. HID_KEYBOARD_T | KEY_MOD_LEFT_SHIFT, // T
  113. HID_KEYBOARD_U | KEY_MOD_LEFT_SHIFT, // U
  114. HID_KEYBOARD_V | KEY_MOD_LEFT_SHIFT, // V
  115. HID_KEYBOARD_W | KEY_MOD_LEFT_SHIFT, // W
  116. HID_KEYBOARD_X | KEY_MOD_LEFT_SHIFT, // X
  117. HID_KEYBOARD_Y | KEY_MOD_LEFT_SHIFT, // Y
  118. HID_KEYBOARD_Z | KEY_MOD_LEFT_SHIFT, // Z
  119. HID_KEYBOARD_OPEN_BRACKET, // [
  120. HID_KEYBOARD_BACKSLASH, // bslash
  121. HID_KEYBOARD_CLOSE_BRACKET, // ]
  122. HID_KEYBOARD_6 | KEY_MOD_LEFT_SHIFT, // ^
  123. HID_KEYBOARD_MINUS | KEY_MOD_LEFT_SHIFT, // _
  124. HID_KEYBOARD_GRAVE_ACCENT, // `
  125. HID_KEYBOARD_A, // a
  126. HID_KEYBOARD_B, // b
  127. HID_KEYBOARD_C, // c
  128. HID_KEYBOARD_D, // d
  129. HID_KEYBOARD_E, // e
  130. HID_KEYBOARD_F, // f
  131. HID_KEYBOARD_G, // g
  132. HID_KEYBOARD_H, // h
  133. HID_KEYBOARD_I, // i
  134. HID_KEYBOARD_J, // j
  135. HID_KEYBOARD_K, // k
  136. HID_KEYBOARD_L, // l
  137. HID_KEYBOARD_M, // m
  138. HID_KEYBOARD_N, // n
  139. HID_KEYBOARD_O, // o
  140. HID_KEYBOARD_P, // p
  141. HID_KEYBOARD_Q, // q
  142. HID_KEYBOARD_R, // r
  143. HID_KEYBOARD_S, // s
  144. HID_KEYBOARD_T, // t
  145. HID_KEYBOARD_U, // u
  146. HID_KEYBOARD_V, // v
  147. HID_KEYBOARD_W, // w
  148. HID_KEYBOARD_X, // x
  149. HID_KEYBOARD_Y, // y
  150. HID_KEYBOARD_Z, // z
  151. HID_KEYBOARD_OPEN_BRACKET | KEY_MOD_LEFT_SHIFT, // {
  152. HID_KEYBOARD_BACKSLASH | KEY_MOD_LEFT_SHIFT, // |
  153. HID_KEYBOARD_CLOSE_BRACKET | KEY_MOD_LEFT_SHIFT, // }
  154. HID_KEYBOARD_GRAVE_ACCENT | KEY_MOD_LEFT_SHIFT, // ~
  155. HID_KEYBOARD_NONE, // DEL
  156. };
  157. typedef struct {
  158. uint32_t vid;
  159. uint32_t pid;
  160. char manuf[32];
  161. char product[32];
  162. } FuriHalUsbHidConfig;
  163. typedef void (*HidStateCallback)(bool state, void* context);
  164. /** ASCII to keycode conversion macro */
  165. #define HID_ASCII_TO_KEY(x) (((uint8_t)x < 128) ? (hid_asciimap[(uint8_t)x]) : HID_KEYBOARD_NONE)
  166. /** HID keyboard leds */
  167. enum HidKeyboardLeds {
  168. HID_KB_LED_NUM = (1 << 0),
  169. HID_KB_LED_CAPS = (1 << 1),
  170. HID_KB_LED_SCROLL = (1 << 2),
  171. };
  172. /** HID mouse buttons */
  173. enum HidMouseButtons {
  174. HID_MOUSE_BTN_LEFT = (1 << 0),
  175. HID_MOUSE_BTN_RIGHT = (1 << 1),
  176. HID_MOUSE_BTN_WHEEL = (1 << 2),
  177. };
  178. /** Get USB HID connection state
  179. *
  180. * @return true / false
  181. */
  182. bool furi_hal_hid_is_connected();
  183. /** Get USB HID keyboard leds state
  184. *
  185. * @return leds state
  186. */
  187. uint8_t furi_hal_hid_get_led_state();
  188. /** Set USB HID connect/disconnect callback
  189. *
  190. * @param cb callback
  191. * @param ctx callback context
  192. */
  193. void furi_hal_hid_set_state_callback(HidStateCallback cb, void* ctx);
  194. /** Set the following key to pressed state and send HID report
  195. *
  196. * @param button key code
  197. */
  198. bool furi_hal_hid_kb_press(uint16_t button);
  199. /** Set the following key to released state and send HID report
  200. *
  201. * @param button key code
  202. */
  203. bool furi_hal_hid_kb_release(uint16_t button);
  204. /** Clear all pressed keys and send HID report
  205. *
  206. */
  207. bool furi_hal_hid_kb_release_all();
  208. /** Set mouse movement and send HID report
  209. *
  210. * @param dx x coordinate delta
  211. * @param dy y coordinate delta
  212. */
  213. bool furi_hal_hid_mouse_move(int8_t dx, int8_t dy);
  214. /** Set mouse button to pressed state and send HID report
  215. *
  216. * @param button key code
  217. */
  218. bool furi_hal_hid_mouse_press(uint8_t button);
  219. /** Set mouse button to released state and send HID report
  220. *
  221. * @param button key code
  222. */
  223. bool furi_hal_hid_mouse_release(uint8_t button);
  224. /** Set mouse wheel position and send HID report
  225. *
  226. * @param delta number of scroll steps
  227. */
  228. bool furi_hal_hid_mouse_scroll(int8_t delta);
  229. /** Set the following consumer key to pressed state and send HID report
  230. *
  231. * @param button key code
  232. */
  233. bool furi_hal_hid_consumer_key_press(uint16_t button);
  234. /** Set the following consumer key to released state and send HID report
  235. *
  236. * @param button key code
  237. */
  238. bool furi_hal_hid_consumer_key_release(uint16_t button);
  239. #ifdef __cplusplus
  240. }
  241. #endif