zephyr/samples/drivers/uart/async_api
Anisetti Avinash Krishna 4675f17fa2 samples: drivers: uart: async_api: Added support for BTL-s
Added support for async api application on BTL-s platform.
Resolves #93408

Signed-off-by: Anisetti Avinash Krishna <anisetti.avinash.krishna@intel.com>
2025-07-24 02:47:43 -04:00
..
boards samples: drivers: uart: async_api: Added support for BTL-s 2025-07-24 02:47:43 -04:00
src
CMakeLists.txt
prj.conf
README.rst
sample.yaml

.. zephyr:code-sample:: uart_async
   :name: UART ASYNC API
   :relevant-api: uart_interface

   Demonstrate the use of the asynchronous API

Overview
********

This sample demonstrates how to use the UART serial driver asynchronous
API through a simple packet transmitter.

Every 5 seconds, 1 to 4 data payloads are generated and queued for
transmission. Every other 5 second period, receiving is enabled through
the asynchronous API.

By default, the UART peripheral that is normally used for the Zephyr shell
is used, so that almost every board should be supported.

Building and Running
********************

Build and flash the sample as follows, changing ``nrf52840dk/nrf52840`` for
your board:

.. zephyr-app-commands::
   :zephyr-app: samples/drivers/uart/async_api
   :board: nrf52840dk/nrf52840
   :goals: build flash
   :compact:

Sample Output
=============

.. code-block:: console

   Loop 0: Packet: 0
   Loop 0: Packet: 1
   Loop 0: Packet: 2
   [00:00:05.001,919] <inf> sample: Loop 0: Sending 3 packets
   [00:00:05.002,008] <inf> sample: RX is now enabled
   Loop 1: Packet: 0
   [00:00:10.002,086] <inf> sample: Loop 1: Sending 1 packets
   [00:00:10.002,138] <inf> sample: RX is now disabled
   Loop 2: Packet: 0
   Loop 2: Packet: 1
   [00:00:15.002,215] <inf> sample: Loop 2: Sending 2 packets
   [00:00:15.002,293] <inf> sample: RX is now enabled
   [00:00:15.009,010] <inf> sample: RX_RDY
                                 68 65 6c 6c 6f 0a                                |hello.
   Loop 3: Packet: 0
   Loop 3: Packet: 1
   Loop 3: Packet: 2
   [00:00:20.002,343] <inf> sample: Loop 3: Sending 3 packets
   [00:00:20.002,424] <inf> sample: RX is now disabled

Note that because the UART transmissions are triggered directly, they will
appear in the serial logs **before** the ``LOG_INF`` message at the top of
the loop, since log writes are typically deferred by several seconds