Same functionality as previous commit. But way more stable and clean. Previous proof of concept approach had issues with random partial or too large messages due to time based method Rework send and receive functions to work more stable - send: encode data with frame (start, end byte) - receive: read each byte one after the other, assemble message, handle actual data in handle function - add semaphore to write operation to prevent parallel write of different data when called from other tasks
56 lines
1.2 KiB
C++
56 lines
1.2 KiB
C++
extern "C"
|
|
{
|
|
#include <stdio.h>
|
|
#include <esp_system.h>
|
|
#include <esp_event.h>
|
|
#include <nvs_flash.h>
|
|
#include "freertos/FreeRTOS.h"
|
|
#include "freertos/task.h"
|
|
#include "driver/gpio.h"
|
|
#include "esp_log.h"
|
|
#include "sdkconfig.h"
|
|
#include <string.h>
|
|
|
|
#include "freertos/queue.h"
|
|
#include "driver/uart.h"
|
|
}
|
|
#include "uart.hpp"
|
|
|
|
static const char * TAG = "uart";
|
|
|
|
|
|
|
|
//==============================
|
|
//====== task_uartReceive ======
|
|
//==============================
|
|
//TODO copy receive task from board_motorctl/uart.cpp
|
|
void task_uartReceive(void *arg){
|
|
while (1) {
|
|
vTaskDelay(200 / portTICK_PERIOD_MS);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
//=============================
|
|
//======= task_uartSend =======
|
|
//=============================
|
|
//repeatedly send structs via uart
|
|
//note: uart_sendStruct() from uart_common.hpp can be used anywhere
|
|
void task_uartSend(void *arg){
|
|
static const char * TAG = "uart-send";
|
|
uartData_test_t data = {123, 0, 1.1};
|
|
ESP_LOGW(TAG, "send task started");
|
|
//repeatedly send data for testing uart
|
|
while (1) {
|
|
vTaskDelay(5000 / portTICK_PERIOD_MS);
|
|
uart_sendStruct<uartData_test_t>(data);
|
|
|
|
//change data values
|
|
data.timestamp = esp_log_timestamp();
|
|
data.id++;
|
|
data.value += 0.6;
|
|
}
|
|
ESP_LOGE(TAG, "loop exit...");
|
|
}
|