main.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. /*
  2. * (c) 2015 flabberast <s3+flabbergast@sdfeu.org>
  3. *
  4. * Based on the following work:
  5. * - Guillaume Duc's raw hid example (MIT License)
  6. * https://github.com/guiduc/usb-hid-chibios-example
  7. * - PJRC Teensy examples (MIT License)
  8. * https://www.pjrc.com/teensy/usb_keyboard.html
  9. * - hasu's TMK keyboard code (GPL v2 and some code Modified BSD)
  10. * https://github.com/tmk/tmk_keyboard/
  11. * - ChibiOS demo code (Apache 2.0 License)
  12. * http://www.chibios.org
  13. *
  14. * Since some GPL'd code is used, this work is licensed under
  15. * GPL v2 or later.
  16. */
  17. #include <ch.h>
  18. #include <hal.h>
  19. #include "usb_main.h"
  20. /* TMK includes */
  21. #include "report.h"
  22. #include "host.h"
  23. #include "host_driver.h"
  24. #include "keyboard.h"
  25. #include "action.h"
  26. #include "action_util.h"
  27. #include "mousekey.h"
  28. #include "led.h"
  29. #include "sendchar.h"
  30. #include "debug.h"
  31. #include "print.h"
  32. #ifndef EARLY_INIT_PERFORM_BOOTLOADER_JUMP
  33. // Change this to be TRUE once we've migrated keyboards to the new init system
  34. // Remember to change docs/platformdev_chibios_earlyinit.md as well.
  35. # define EARLY_INIT_PERFORM_BOOTLOADER_JUMP FALSE
  36. #endif
  37. #ifdef SLEEP_LED_ENABLE
  38. # include "sleep_led.h"
  39. #endif
  40. #ifdef SERIAL_LINK_ENABLE
  41. # include "serial_link/system/serial_link.h"
  42. #endif
  43. #ifdef VISUALIZER_ENABLE
  44. # include "visualizer/visualizer.h"
  45. #endif
  46. #ifdef MIDI_ENABLE
  47. # include "qmk_midi.h"
  48. #endif
  49. #ifdef STM32_EEPROM_ENABLE
  50. # include "eeprom_stm32.h"
  51. #endif
  52. #ifdef EEPROM_DRIVER
  53. # include "eeprom_driver.h"
  54. #endif
  55. #include "suspend.h"
  56. #include "wait.h"
  57. /* -------------------------
  58. * TMK host driver defs
  59. * -------------------------
  60. */
  61. /* declarations */
  62. uint8_t keyboard_leds(void);
  63. void send_keyboard(report_keyboard_t *report);
  64. void send_mouse(report_mouse_t *report);
  65. void send_system(uint16_t data);
  66. void send_consumer(uint16_t data);
  67. /* host struct */
  68. host_driver_t chibios_driver = {keyboard_leds, send_keyboard, send_mouse, send_system, send_consumer};
  69. #ifdef VIRTSER_ENABLE
  70. void virtser_task(void);
  71. #endif
  72. #ifdef RAW_ENABLE
  73. void raw_hid_task(void);
  74. #endif
  75. #ifdef CONSOLE_ENABLE
  76. void console_task(void);
  77. #endif
  78. #ifdef MIDI_ENABLE
  79. void midi_ep_task(void);
  80. #endif
  81. /* TESTING
  82. * Amber LED blinker thread, times are in milliseconds.
  83. */
  84. /* set this variable to non-zero anywhere to blink once */
  85. // static THD_WORKING_AREA(waThread1, 128);
  86. // static THD_FUNCTION(Thread1, arg) {
  87. // (void)arg;
  88. // chRegSetThreadName("blinker");
  89. // while (true) {
  90. // systime_t time;
  91. // time = USB_DRIVER.state == USB_ACTIVE ? 250 : 500;
  92. // palClearLine(LINE_CAPS_LOCK);
  93. // chSysPolledDelayX(MS2RTC(STM32_HCLK, time));
  94. // palSetLine(LINE_CAPS_LOCK);
  95. // chSysPolledDelayX(MS2RTC(STM32_HCLK, time));
  96. // }
  97. // }
  98. /* Early initialisation
  99. */
  100. __attribute__((weak)) void early_hardware_init_pre(void) {
  101. #if EARLY_INIT_PERFORM_BOOTLOADER_JUMP
  102. void enter_bootloader_mode_if_requested(void);
  103. enter_bootloader_mode_if_requested();
  104. #endif // EARLY_INIT_PERFORM_BOOTLOADER_JUMP
  105. }
  106. __attribute__((weak)) void early_hardware_init_post(void) {}
  107. __attribute__((weak)) void board_init(void) {}
  108. // This overrides what's normally in ChibiOS board definitions
  109. void __early_init(void) {
  110. early_hardware_init_pre();
  111. // This is the renamed equivalent of __early_init in the board.c file
  112. void __chibios_override___early_init(void);
  113. __chibios_override___early_init();
  114. early_hardware_init_post();
  115. }
  116. // This overrides what's normally in ChibiOS board definitions
  117. void boardInit(void) {
  118. // This is the renamed equivalent of boardInit in the board.c file
  119. void __chibios_override_boardInit(void);
  120. __chibios_override_boardInit();
  121. board_init();
  122. }
  123. /* Main thread
  124. */
  125. int main(void) {
  126. /* ChibiOS/RT init */
  127. halInit();
  128. chSysInit();
  129. #ifdef STM32_EEPROM_ENABLE
  130. EEPROM_Init();
  131. #endif
  132. #ifdef EEPROM_DRIVER
  133. eeprom_driver_init();
  134. #endif
  135. // TESTING
  136. // chThdCreateStatic(waThread1, sizeof(waThread1), NORMALPRIO, Thread1, NULL);
  137. keyboard_setup();
  138. /* Init USB */
  139. usb_event_queue_init();
  140. init_usb_driver(&USB_DRIVER);
  141. #ifdef MIDI_ENABLE
  142. setup_midi();
  143. #endif
  144. #ifdef SERIAL_LINK_ENABLE
  145. init_serial_link();
  146. #endif
  147. #ifdef VISUALIZER_ENABLE
  148. visualizer_init();
  149. #endif
  150. host_driver_t *driver = NULL;
  151. /* Wait until the USB or serial link is active */
  152. while (true) {
  153. #if defined(WAIT_FOR_USB) || defined(SERIAL_LINK_ENABLE)
  154. if (USB_DRIVER.state == USB_ACTIVE) {
  155. driver = &chibios_driver;
  156. break;
  157. }
  158. #else
  159. driver = &chibios_driver;
  160. break;
  161. #endif
  162. #ifdef SERIAL_LINK_ENABLE
  163. if (is_serial_link_connected()) {
  164. driver = get_serial_link_driver();
  165. break;
  166. }
  167. serial_link_update();
  168. #endif
  169. wait_ms(50);
  170. }
  171. /* Do need to wait here!
  172. * Otherwise the next print might start a transfer on console EP
  173. * before the USB is completely ready, which sometimes causes
  174. * HardFaults.
  175. */
  176. wait_ms(50);
  177. print("USB configured.\n");
  178. /* init TMK modules */
  179. keyboard_init();
  180. host_set_driver(driver);
  181. #ifdef SLEEP_LED_ENABLE
  182. sleep_led_init();
  183. #endif
  184. print("Keyboard start.\n");
  185. /* Main loop */
  186. while (true) {
  187. usb_event_queue_task();
  188. #if !defined(NO_USB_STARTUP_CHECK)
  189. if (USB_DRIVER.state == USB_SUSPENDED) {
  190. print("[s]");
  191. # ifdef VISUALIZER_ENABLE
  192. visualizer_suspend();
  193. # endif
  194. while (USB_DRIVER.state == USB_SUSPENDED) {
  195. /* Do this in the suspended state */
  196. # ifdef SERIAL_LINK_ENABLE
  197. serial_link_update();
  198. # endif
  199. suspend_power_down(); // on AVR this deep sleeps for 15ms
  200. /* Remote wakeup */
  201. if (suspend_wakeup_condition()) {
  202. usbWakeupHost(&USB_DRIVER);
  203. restart_usb_driver(&USB_DRIVER);
  204. }
  205. }
  206. /* Woken up */
  207. // variables has been already cleared by the wakeup hook
  208. send_keyboard_report();
  209. # ifdef MOUSEKEY_ENABLE
  210. mousekey_send();
  211. # endif /* MOUSEKEY_ENABLE */
  212. # ifdef VISUALIZER_ENABLE
  213. visualizer_resume();
  214. # endif
  215. }
  216. #endif
  217. keyboard_task();
  218. #ifdef CONSOLE_ENABLE
  219. console_task();
  220. #endif
  221. #ifdef MIDI_ENABLE
  222. midi_ep_task();
  223. #endif
  224. #ifdef VIRTSER_ENABLE
  225. virtser_task();
  226. #endif
  227. #ifdef RAW_ENABLE
  228. raw_hid_task();
  229. #endif
  230. // Run housekeeping
  231. housekeeping_task_kb();
  232. housekeeping_task_user();
  233. }
  234. }