2018-04-11 02:56:00 -04:00
|
|
|
/* Uart Events Example
|
|
|
|
|
|
|
|
This example code is in the Public Domain (or CC0 licensed, at your option.)
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, this
|
|
|
|
software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
|
|
CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
#include "esp_system.h"
|
|
|
|
#include "nvs_flash.h"
|
|
|
|
#include "driver/uart.h"
|
|
|
|
#include "freertos/queue.h"
|
|
|
|
#include "esp_log.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This is a example example which echos any data it receives on UART back to the sender.
|
|
|
|
*
|
|
|
|
* - port: UART2
|
|
|
|
* - rx buffer: on
|
|
|
|
* - tx buffer: off
|
|
|
|
* - flow control: off
|
|
|
|
*
|
|
|
|
* This example has been tested on a 3 node RS485 Serial Bus
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-06-27 10:48:14 -04:00
|
|
|
// Note: UART2 default pins IO16, IO17 do not work on ESP32-WROVER module
|
2018-04-11 02:56:00 -04:00
|
|
|
// because these pins connected to PSRAM
|
2018-06-27 10:48:14 -04:00
|
|
|
#define ECHO_TEST_TXD (23)
|
|
|
|
#define ECHO_TEST_RXD (22)
|
2018-04-11 02:56:00 -04:00
|
|
|
|
|
|
|
// RTS for RS485 Half-Duplex Mode manages DE/~RE
|
|
|
|
#define ECHO_TEST_RTS (18)
|
|
|
|
|
|
|
|
// CTS is not used in RS485 Half-Duplex Mode
|
|
|
|
#define ECHO_TEST_CTS UART_PIN_NO_CHANGE
|
|
|
|
|
|
|
|
#define BUF_SIZE (127)
|
|
|
|
#define BAUD_RATE (115200)
|
|
|
|
|
|
|
|
// Read packet timeout
|
|
|
|
#define PACKET_READ_TICS (100 / portTICK_RATE_MS)
|
|
|
|
#define ECHO_TASK_STACK_SIZE (2048)
|
|
|
|
#define ECHO_TASK_PRIO (10)
|
2019-07-01 06:00:10 -04:00
|
|
|
#define ECHO_UART_PORT (UART_NUM_MAX - 1)
|
2018-04-11 02:56:00 -04:00
|
|
|
|
2018-06-27 10:48:14 -04:00
|
|
|
static const char *TAG = "RS485_ECHO_APP";
|
|
|
|
|
2018-04-11 02:56:00 -04:00
|
|
|
// An example of echo test with hardware flow control on UART
|
2019-07-30 00:53:48 -04:00
|
|
|
static void echo_task(void *arg)
|
2018-04-11 02:56:00 -04:00
|
|
|
{
|
|
|
|
const int uart_num = ECHO_UART_PORT;
|
|
|
|
uart_config_t uart_config = {
|
|
|
|
.baud_rate = BAUD_RATE,
|
|
|
|
.data_bits = UART_DATA_8_BITS,
|
|
|
|
.parity = UART_PARITY_DISABLE,
|
|
|
|
.stop_bits = UART_STOP_BITS_1,
|
|
|
|
.flow_ctrl = UART_HW_FLOWCTRL_DISABLE,
|
|
|
|
.rx_flow_ctrl_thresh = 122,
|
2019-04-17 08:19:44 -04:00
|
|
|
.source_clk = UART_SCLK_APB,
|
2018-04-11 02:56:00 -04:00
|
|
|
};
|
|
|
|
|
2018-06-27 10:48:14 -04:00
|
|
|
// Set UART log level
|
|
|
|
esp_log_level_set(TAG, ESP_LOG_INFO);
|
|
|
|
|
|
|
|
ESP_LOGI(TAG, "Start RS485 application test and configure UART.");
|
2018-04-11 02:56:00 -04:00
|
|
|
|
2019-04-17 08:19:44 -04:00
|
|
|
// Install UART driver (we don't need an event queue here)
|
|
|
|
// In this example we don't even use a buffer for sending data.
|
|
|
|
uart_driver_install(uart_num, BUF_SIZE * 2, 0, 0, NULL, 0);
|
2018-04-11 02:56:00 -04:00
|
|
|
// Configure UART parameters
|
|
|
|
uart_param_config(uart_num, &uart_config);
|
|
|
|
|
2018-06-27 10:48:14 -04:00
|
|
|
ESP_LOGI(TAG, "UART set pins, mode and install driver.");
|
2018-04-11 02:56:00 -04:00
|
|
|
// Set UART1 pins(TX: IO23, RX: I022, RTS: IO18, CTS: IO19)
|
|
|
|
uart_set_pin(uart_num, ECHO_TEST_TXD, ECHO_TEST_RXD, ECHO_TEST_RTS, ECHO_TEST_CTS);
|
|
|
|
|
|
|
|
// Set RS485 half duplex mode
|
|
|
|
uart_set_mode(uart_num, UART_MODE_RS485_HALF_DUPLEX);
|
|
|
|
|
|
|
|
// Allocate buffers for UART
|
|
|
|
uint8_t* data = (uint8_t*) malloc(BUF_SIZE);
|
|
|
|
|
2018-06-27 10:48:14 -04:00
|
|
|
ESP_LOGI(TAG, "UART start recieve loop.\r\n");
|
2018-04-11 02:56:00 -04:00
|
|
|
uart_write_bytes(uart_num, "Start RS485 UART test.\r\n", 24);
|
|
|
|
|
|
|
|
while(1) {
|
|
|
|
//Read data from UART
|
|
|
|
int len = uart_read_bytes(uart_num, data, BUF_SIZE, PACKET_READ_TICS);
|
|
|
|
|
|
|
|
//Write data back to UART
|
|
|
|
if (len > 0) {
|
|
|
|
uart_write_bytes(uart_num, "\r\n", 2);
|
|
|
|
char prefix[] = "RS485 Received: [";
|
|
|
|
uart_write_bytes(uart_num, prefix, (sizeof(prefix) - 1));
|
|
|
|
|
2018-06-27 10:48:14 -04:00
|
|
|
ESP_LOGI(TAG, "Received %u bytes:", len);
|
|
|
|
printf("[ ");
|
2018-04-11 02:56:00 -04:00
|
|
|
for (int i = 0; i < len; i++) {
|
|
|
|
printf("0x%.2X ", (uint8_t)data[i]);
|
|
|
|
uart_write_bytes(uart_num, (const char*)&data[i], 1);
|
|
|
|
// Add a Newline character if you get a return charater from paste (Paste tests multibyte receipt/buffer)
|
|
|
|
if (data[i] == '\r') {
|
|
|
|
uart_write_bytes(uart_num, "\n", 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
printf("] \n");
|
|
|
|
uart_write_bytes(uart_num, "]\r\n", 3);
|
|
|
|
} else {
|
|
|
|
// Echo a "." to show we are alive while we wait for input
|
|
|
|
uart_write_bytes(uart_num, ".", 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-16 05:33:30 -04:00
|
|
|
void app_main(void)
|
2018-04-11 02:56:00 -04:00
|
|
|
{
|
|
|
|
//A uart read/write example without event queue;
|
|
|
|
xTaskCreate(echo_task, "uart_echo_task", ECHO_TASK_STACK_SIZE, NULL, ECHO_TASK_PRIO, NULL);
|
|
|
|
}
|