esp-idf/examples/peripherals/uart/uart_async_rxtxtasks
..
main
CMakeLists.txt
Makefile
README.md

README.md

UART Asynchronous Example with Separate Receive and Transfer Tasks

(See the README.md file in the upper level 'examples' directory for more information about examples.)

This example demonstrates how two asynchronous tasks can use the same UART interface for communication. One can use this example to develop more complex applications for serial communication.

The example starts two FreeRTOS tasks:

  1. The first task periodically transmits Hello world via the UART.
  2. The second task task listens, receives and prints data from the UART.

How to use example

Hardware Required

The example can be run on any commonly available ESP32 development board. You will need a USB cable to connect the development board to a computer, and a simple one-wire cable for shorting two pins of the board.

Setup the Hardware

The RXD_PIN and TXD_PIN which are configurable in the code (by default GPIO4 and GPIO5) need to be shorted in order to receive back the same data which were sent out.

Configure the project

idf.py menuconfig

Build and Flash

Build the project and flash it to the board, then run monitor tool to view serial output:

idf.py -p PORT flash monitor

(To exit the serial monitor, type Ctrl-].)

See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects.

Example Output

You will receive the following repeating output from the monitoring console:

...
I (3261) TX_TASK: Wrote 11 bytes
I (4261) RX_TASK: Read 11 bytes: 'Hello world'
I (4261) RX_TASK: 0x3ffb821c   48 65 6c 6c 6f 20 77 6f  72 6c 64                 |Hello world|
...

Troubleshooting

If you do not see any output from RX_TASK then check if you have the RXD_PIN and TXD_PIN pins shorted on the board.