uart.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. #include "uart.h"
  2. #define UART_CH (FuriHalSerialIdUsart)
  3. #define LP_UART_CH (FuriHalSerialIdLpuart)
  4. #define BAUDRATE (115200UL)
  5. struct Uart {
  6. void* app;
  7. FuriThread* rx_thread;
  8. FuriHalSerialHandle* serial_handle;
  9. FuriHalSerialId channel;
  10. FuriThread* worker_thread;
  11. FuriStreamBuffer* rx_stream;
  12. uint8_t rx_buf[RX_BUF_SIZE + 1];
  13. void (*handle_rx_data_cb)(uint8_t* buf, size_t len, void* context);
  14. };
  15. typedef enum {
  16. WorkerEvtStop = (1 << 0),
  17. WorkerEvtRxDone = (1 << 1),
  18. } WorkerEventFlags;
  19. #define WORKER_ALL_RX_EVENTS (WorkerEvtStop | WorkerEvtRxDone)
  20. void uart_set_handle_rx_data_cb(
  21. Uart* uart,
  22. void (*handle_rx_data_cb)(uint8_t* buf, size_t len, void* context)) {
  23. furi_assert(uart);
  24. uart->handle_rx_data_cb = handle_rx_data_cb;
  25. }
  26. static void wifi_marauder_uart_on_irq_cb(
  27. FuriHalSerialHandle* handle,
  28. FuriHalSerialRxEvent event,
  29. void* context) {
  30. Uart* uart = (Uart*)context;
  31. if(event == FuriHalSerialRxEventData) {
  32. uint8_t data = furi_hal_serial_async_rx(handle);
  33. furi_stream_buffer_send(uart->rx_stream, &data, 1, 0);
  34. furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtRxDone);
  35. }
  36. }
  37. static void
  38. uart_on_irq_cb(FuriHalSerialHandle* handle, FuriHalSerialRxEvent event, void* context) {
  39. Uart* uart = (Uart*)context;
  40. UNUSED(handle);
  41. if(event == FuriHalSerialRxEventData) {
  42. uint8_t data = furi_hal_serial_async_rx(handle);
  43. furi_stream_buffer_send(uart->rx_stream, &data, 1, 0);
  44. furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtRxDone);
  45. }
  46. }
  47. // Define una constante para el prefijo que estamos buscando
  48. #define JSON_PREFIX "JSON:"
  49. // Variables globales
  50. static char json_buffer[2048]; // Ajusta el tamaño según tus necesidades
  51. static size_t json_buffer_index = 0;
  52. static bool json_capture_active = false;
  53. // static bool json_finded = false;
  54. // Prototipo de la función
  55. // static void process_json_buffer();
  56. static void process_json_buffer(void* context) {
  57. Uart* uart = (Uart*)context;
  58. // Agregamos el terminador nulo al final del buffer
  59. json_buffer[json_buffer_index] = '\0';
  60. if(uart->handle_rx_data_cb) {
  61. uart->handle_rx_data_cb((uint8_t*)json_buffer, json_buffer_index, uart->app);
  62. memset(json_buffer, 0, sizeof(json_buffer));
  63. }
  64. // Reiniciamos el buffer
  65. json_buffer_index = 0;
  66. }
  67. static void uart_echo_push_to_list(void* context, uint8_t data) {
  68. Uart* uart = (Uart*)context;
  69. if(!json_capture_active) {
  70. if(data == JSON_PREFIX[json_buffer_index]) {
  71. json_buffer[json_buffer_index++] = data; // Agregar el carácter al buffer
  72. if(json_buffer_index == strlen(JSON_PREFIX)) {
  73. // Encontramos el prefijo, comenzamos a capturar
  74. json_buffer_index = 0;
  75. json_capture_active = true;
  76. }
  77. } else {
  78. // Reiniciamos el índice si no coincide con el prefijo
  79. json_buffer_index = 0;
  80. }
  81. } else {
  82. // Capturamos caracteres hasta encontrar '\n'
  83. json_buffer[json_buffer_index++] = data;
  84. if(data == '\n') {
  85. // Terminamos de capturar la línea, procesamos el buffer
  86. json_capture_active = false;
  87. process_json_buffer(uart);
  88. }
  89. }
  90. }
  91. static int32_t uart_worker(void* context) {
  92. furi_assert(context);
  93. Uart* uart = (Uart*)context;
  94. while(1) {
  95. uint32_t events =
  96. furi_thread_flags_wait(WORKER_ALL_RX_EVENTS, FuriFlagWaitAny, FuriWaitForever);
  97. furi_check((events & FuriFlagError) == 0);
  98. if(events & WorkerEvtStop) break;
  99. if(events & WorkerEvtRxDone) {
  100. if(uart->channel == UART_CH) {
  101. size_t length = 0;
  102. do {
  103. uint8_t data[64];
  104. length = furi_stream_buffer_receive(uart->rx_stream, data, 64, 0);
  105. if(length > 0) {
  106. for(size_t i = 0; i < length; i++) {
  107. uart_echo_push_to_list(uart, data[i]);
  108. // FURI_LOG_I("UART", "[in]: %c - %d", (const char)data[i], data[i]);
  109. }
  110. }
  111. } while(length > 0);
  112. } else if(uart->channel == LP_UART_CH) {
  113. size_t len =
  114. furi_stream_buffer_receive(uart->rx_stream, uart->rx_buf, RX_BUF_SIZE, 0);
  115. if(len > 0) {
  116. if(uart->handle_rx_data_cb)
  117. uart->handle_rx_data_cb(uart->rx_buf, len, uart->app);
  118. }
  119. }
  120. }
  121. }
  122. furi_stream_buffer_free(uart->rx_stream);
  123. return 0;
  124. }
  125. void uart_tx(void* app, uint8_t* data, size_t len) {
  126. Uart* uart = (Uart*)app;
  127. furi_hal_serial_tx(uart->serial_handle, data, len);
  128. }
  129. Uart* _uart_init(void* app, FuriHalSerialId channel, const char* thread_name) {
  130. Uart* uart = (Uart*)malloc(sizeof(Uart));
  131. uart->app = app;
  132. uart->channel = channel;
  133. uart->rx_stream = furi_stream_buffer_alloc(RX_BUF_SIZE, 1);
  134. uart->rx_thread = furi_thread_alloc();
  135. furi_thread_set_name(uart->rx_thread, thread_name);
  136. furi_thread_set_stack_size(uart->rx_thread, 1024);
  137. furi_thread_set_context(uart->rx_thread, uart);
  138. furi_thread_set_callback(uart->rx_thread, uart_worker);
  139. furi_thread_start(uart->rx_thread);
  140. uart->serial_handle = furi_hal_serial_control_acquire(channel);
  141. if(!uart->serial_handle) {
  142. furi_delay_ms(5000);
  143. }
  144. furi_check(uart->serial_handle);
  145. furi_hal_serial_init(uart->serial_handle, BAUDRATE);
  146. furi_hal_serial_async_rx_start(
  147. uart->serial_handle,
  148. channel == FuriHalSerialIdUsart ? uart_on_irq_cb : wifi_marauder_uart_on_irq_cb,
  149. uart,
  150. false);
  151. return uart;
  152. }
  153. Uart* usart_init(void* app) {
  154. return _uart_init(app, UART_CH, "UartRxThread");
  155. }
  156. Uart* lp_uart_init(void* app) {
  157. return _uart_init(app, LP_UART_CH, "LPUartRxThread");
  158. }
  159. void uart_free(Uart* uart) {
  160. furi_assert(uart);
  161. furi_hal_serial_async_rx_stop(uart->serial_handle);
  162. furi_hal_serial_deinit(uart->serial_handle);
  163. furi_hal_serial_control_release(uart->serial_handle);
  164. furi_thread_flags_set(furi_thread_get_id(uart->rx_thread), WorkerEvtStop);
  165. furi_thread_join(uart->rx_thread);
  166. furi_thread_free(uart->rx_thread);
  167. free(uart);
  168. }