1.. _uart_api: 2 3Universal Asynchronous Receiver-Transmitter (UART) 4################################################## 5 6Overview 7******** 8 9Zephyr provides three different ways to access the UART peripheral. Depending 10on the method, different API functions are used according to below sections: 11 121. :ref:`uart_polling_api` 132. :ref:`uart_interrupt_api` 143. :ref:`uart_async_api` using :ref:`dma_api` 15 16Polling is the most basic method to access the UART peripheral. The reading 17function, :c:func:`uart_poll_in`, is a non-blocking function and returns a character 18or ``-1`` when no valid data is available. The writing function, 19:c:func:`uart_poll_out`, is a blocking function and the thread waits until the given 20character is sent. 21 22With the Interrupt-driven API, possibly slow communication can happen in the 23background while the thread continues with other tasks. The Kernel's 24:ref:`kernel_data_passing_api` features can be used to communicate between 25the thread and the UART driver. 26 27The Asynchronous API allows to read and write data in the background using DMA 28without interrupting the MCU at all. However, the setup is more complex 29than the other methods. 30 31.. warning:: 32 33 Interrupt-driven API and the Asynchronous API should NOT be used at 34 the same time for the same hardware peripheral, since both APIs require 35 hardware interrupts to function properly. Using the callbacks for both 36 APIs would result in interference between each other. 37 :kconfig:option:`CONFIG_UART_EXCLUSIVE_API_CALLBACKS` is enabled by default 38 so that only the callbacks associated with one API is active at a time. 39 40 41Configuration Options 42********************* 43 44Most importantly, the Kconfig options define whether the polling API (default), 45the interrupt-driven API or the asynchronous API can be used. Only enable the 46features you need in order to minimize memory footprint. 47 48Related configuration options: 49 50* :kconfig:option:`CONFIG_SERIAL` 51* :kconfig:option:`CONFIG_UART_INTERRUPT_DRIVEN` 52* :kconfig:option:`CONFIG_UART_ASYNC_API` 53* :kconfig:option:`CONFIG_UART_WIDE_DATA` 54* :kconfig:option:`CONFIG_UART_USE_RUNTIME_CONFIGURE` 55* :kconfig:option:`CONFIG_UART_LINE_CTRL` 56* :kconfig:option:`CONFIG_UART_DRV_CMD` 57 58 59API Reference 60************* 61 62.. doxygengroup:: uart_interface 63 64 65.. _uart_polling_api: 66 67Polling API 68=========== 69 70.. doxygengroup:: uart_polling 71 72 73.. _uart_interrupt_api: 74 75Interrupt-driven API 76==================== 77 78.. doxygengroup:: uart_interrupt 79 80 81.. _uart_async_api: 82 83Asynchronous API 84================ 85 86.. doxygengroup:: uart_async 87