|
@@ -2,31 +2,59 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
int32_t uhf_uart_worker_callback(void *ctx){
|
|
int32_t uhf_uart_worker_callback(void *ctx){
|
|
|
- // UHFUart* uart = (UHFUart*)ctx;
|
|
|
|
|
- UNUSED(ctx);
|
|
|
|
|
- // while(true){
|
|
|
|
|
- // if(uart->tick > 0){
|
|
|
|
|
- // furi_thread_sleep(uart->tick);
|
|
|
|
|
- // uart->tick--;
|
|
|
|
|
- // }
|
|
|
|
|
- // }
|
|
|
|
|
|
|
+ UHFUart* uart = (UHFUart*)ctx;
|
|
|
|
|
+ // FuriString* line = furi_string_alloc();
|
|
|
|
|
+ uint32_t events;
|
|
|
|
|
+ events = furi_thread_flags_wait(
|
|
|
|
|
+ UHFUartWorkerWaitingDataFlag | UHFUartWorkerExitingFlag, FuriFlagWaitAny, FuriWaitForever
|
|
|
|
|
+ );
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "WAITING DATA");
|
|
|
|
|
+ if(events & UHFUartWorkerWaitingDataFlag){
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "STARTED");
|
|
|
|
|
+ size_t length_read = 0;
|
|
|
|
|
+ do{
|
|
|
|
|
+
|
|
|
|
|
+ uint8_t read_buffer[1];
|
|
|
|
|
+ length_read = furi_stream_buffer_receive(uart->rx_buff_stream, read_buffer, 1, 0);
|
|
|
|
|
+ if(length_read > 0){
|
|
|
|
|
+ // int i = 0;
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "FRAME START");
|
|
|
|
|
+ do{
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "UHF UART RX: %02X", read_buffer[0]);
|
|
|
|
|
+ length_read = furi_stream_buffer_receive(uart->rx_buff_stream, read_buffer, 1, 0);
|
|
|
|
|
+ }while(read_buffer[0] != UHF_UART_FRAME_END && length_read > 0);
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "UHF UART RX: %02X", read_buffer[0]);
|
|
|
|
|
+ furi_stream_buffer_reset(uart->rx_buff_stream);
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "FRAME END");
|
|
|
|
|
+ }
|
|
|
|
|
+ }while((events & UHFUartWorkerExitingFlag) != UHFUartWorkerExitingFlag);
|
|
|
|
|
+ FURI_LOG_E("UHF_UART_WK_CB", "EXITING");
|
|
|
|
|
+ }
|
|
|
return 0;
|
|
return 0;
|
|
|
}
|
|
}
|
|
|
void uhf_uart_default_rx_callback(FuriHalSerialHandle *handle, FuriHalSerialRxEvent event, void* ctx) {
|
|
void uhf_uart_default_rx_callback(FuriHalSerialHandle *handle, FuriHalSerialRxEvent event, void* ctx) {
|
|
|
UHFUart* uart = (UHFUart*)ctx;
|
|
UHFUart* uart = (UHFUart*)ctx;
|
|
|
- Buffer* buffer = (Buffer*)uart->buffer;
|
|
|
|
|
- if(buffer->closed) return; // buffer closed
|
|
|
|
|
- if(event != FuriHalSerialRxEventData) return; // not byte received
|
|
|
|
|
- uint8_t data = furi_hal_serial_async_rx(handle); // read data
|
|
|
|
|
- buffer_append_single(buffer, data); // append data
|
|
|
|
|
- if(data == UHF_UART_FRAME_END) buffer_close(buffer); // end of frame
|
|
|
|
|
- uart->tick = UHF_UART_WAIT_TICK; // reset tick
|
|
|
|
|
|
|
+ if(event == FuriHalSerialRxEventData){
|
|
|
|
|
+ uint8_t data = furi_hal_serial_async_rx(handle);
|
|
|
|
|
+ // FURI_LOG_E("UHF_UART_RB_CB", "UHF UART RX: %02X", data);
|
|
|
|
|
+ furi_stream_buffer_send(uart->rx_buff_stream, (void*)&data, 1, 0);
|
|
|
|
|
+ furi_thread_flags_set(furi_thread_get_id(uart->thread), UHFUartWorkerWaitingDataFlag);
|
|
|
|
|
+ }
|
|
|
|
|
+ // Buffer* buffer = (Buffer*)uart->buffer;
|
|
|
|
|
+ // if(buffer->closed) return; // buffer closed
|
|
|
|
|
+ // if(event != FuriHalSerialRxEventData) return; // not byte received
|
|
|
|
|
+ // uint8_t data = furi_hal_serial_async_rx(handle); // read data
|
|
|
|
|
+ // FURI_LOG_E("UHF_UART_CB", "UHF UART RX: %02X", data);
|
|
|
|
|
+ // buffer_append_single(buffer, data); // append data
|
|
|
|
|
+ // if(data == UHF_UART_FRAME_END) buffer_close(buffer); // end of frame
|
|
|
|
|
+ // uart->tick = UHF_UART_WAIT_TICK; // reset tick
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
UHFUart* uhf_uart_alloc(){
|
|
UHFUart* uhf_uart_alloc(){
|
|
|
UHFUart *uart = (UHFUart*)malloc(sizeof(UHFUart));
|
|
UHFUart *uart = (UHFUart*)malloc(sizeof(UHFUart));
|
|
|
uart->bus = FuriHalBusUSART1;
|
|
uart->bus = FuriHalBusUSART1;
|
|
|
uart->handle = furi_hal_serial_control_acquire(FuriHalSerialIdUsart);
|
|
uart->handle = furi_hal_serial_control_acquire(FuriHalSerialIdUsart);
|
|
|
|
|
+ uart->rx_buff_stream = furi_stream_buffer_alloc(UHF_UART_RX_BUFFER_SIZE, 1);
|
|
|
uart->init_by_app = !furi_hal_bus_is_enabled(uart->bus);
|
|
uart->init_by_app = !furi_hal_bus_is_enabled(uart->bus);
|
|
|
uart->tick = UHF_UART_WAIT_TICK;
|
|
uart->tick = UHF_UART_WAIT_TICK;
|
|
|
if(uart->init_by_app){
|
|
if(uart->init_by_app){
|
|
@@ -41,9 +69,13 @@ UHFUart* uhf_uart_alloc(){
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
void uhf_uart_free(UHFUart* uart){
|
|
void uhf_uart_free(UHFUart* uart){
|
|
|
- // furi_thread_flags_set(furi_thread_get_id(uart->thread), UHFUartWorkerExitingFlag);
|
|
|
|
|
|
|
+ furi_assert(uart);
|
|
|
|
|
+ furi_assert(uart->thread);
|
|
|
|
|
+
|
|
|
|
|
+ furi_thread_flags_set(furi_thread_get_id(uart->thread), UHFUartWorkerExitingFlag);
|
|
|
furi_thread_join(uart->thread);
|
|
furi_thread_join(uart->thread);
|
|
|
furi_thread_free(uart->thread);
|
|
furi_thread_free(uart->thread);
|
|
|
|
|
+ furi_stream_buffer_free(uart->rx_buff_stream);
|
|
|
buffer_free(uart->buffer);
|
|
buffer_free(uart->buffer);
|
|
|
if(uart->init_by_app){
|
|
if(uart->init_by_app){
|
|
|
furi_hal_serial_deinit(uart->handle);
|
|
furi_hal_serial_deinit(uart->handle);
|