furi_hal_console.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. #include <furi_hal_console.h>
  2. #include <furi_hal_uart.h>
  3. #include <stdbool.h>
  4. #include <stm32wbxx_ll_gpio.h>
  5. #include <stm32wbxx_ll_usart.h>
  6. #include <m-string.h>
  7. #include <utilities_conf.h>
  8. #include <furi.h>
  9. #define TAG "FuriHalConsole"
  10. #ifdef HEAP_PRINT_DEBUG
  11. #define CONSOLE_BAUDRATE 1843200
  12. #else
  13. #define CONSOLE_BAUDRATE 230400
  14. #endif
  15. volatile bool furi_hal_console_alive = false;
  16. void furi_hal_console_init() {
  17. furi_hal_uart_init(FuriHalUartIdUSART1, CONSOLE_BAUDRATE);
  18. furi_hal_console_alive = true;
  19. }
  20. void furi_hal_console_enable() {
  21. furi_hal_uart_set_irq_cb(FuriHalUartIdUSART1, NULL, NULL);
  22. while(!LL_USART_IsActiveFlag_TC(USART1))
  23. ;
  24. furi_hal_uart_set_br(FuriHalUartIdUSART1, CONSOLE_BAUDRATE);
  25. furi_hal_console_alive = true;
  26. }
  27. void furi_hal_console_disable() {
  28. while(!LL_USART_IsActiveFlag_TC(USART1))
  29. ;
  30. furi_hal_console_alive = false;
  31. }
  32. void furi_hal_console_tx(const uint8_t* buffer, size_t buffer_size) {
  33. if(!furi_hal_console_alive) return;
  34. FURI_CRITICAL_ENTER();
  35. // Transmit data
  36. furi_hal_uart_tx(FuriHalUartIdUSART1, (uint8_t*)buffer, buffer_size);
  37. // Wait for TC flag to be raised for last char
  38. while(!LL_USART_IsActiveFlag_TC(USART1))
  39. ;
  40. FURI_CRITICAL_EXIT();
  41. }
  42. void furi_hal_console_tx_with_new_line(const uint8_t* buffer, size_t buffer_size) {
  43. if(!furi_hal_console_alive) return;
  44. FURI_CRITICAL_ENTER();
  45. // Transmit data
  46. furi_hal_uart_tx(FuriHalUartIdUSART1, (uint8_t*)buffer, buffer_size);
  47. // Transmit new line symbols
  48. furi_hal_uart_tx(FuriHalUartIdUSART1, (uint8_t*)"\r\n", 2);
  49. // Wait for TC flag to be raised for last char
  50. while(!LL_USART_IsActiveFlag_TC(USART1))
  51. ;
  52. FURI_CRITICAL_EXIT();
  53. }
  54. void furi_hal_console_printf(const char format[], ...) {
  55. string_t string;
  56. va_list args;
  57. va_start(args, format);
  58. string_init_vprintf(string, format, args);
  59. va_end(args);
  60. furi_hal_console_tx((const uint8_t*)string_get_cstr(string), string_size(string));
  61. string_clear(string);
  62. }
  63. void furi_hal_console_puts(const char* data) {
  64. furi_hal_console_tx((const uint8_t*)data, strlen(data));
  65. }