

Hello, and welcome to this presentation of the STM32 Universal Synchronous/Asynchronous Receiver/Transmitter Interface. It covers the main features of this USART interface, which is widely used for serial communications in embedded systems.



The USART is a very flexible serial module that supports:

- Asynchronous UART communication,
- SPI (serial peripheral interface) master mode,
- LIN (local interconnect network) mode.

It can also interface with ISO/IEC 7816 smartcards and IrDA devices.

It also provides certain features that are useful when implementing Modbus communications.

Applications making use of the USART benefit from the easy and inexpensive connection between devices, which only requires a few pins.

In addition, the USART peripheral is functional in lowpower modes.

## Key features •

- Fully programmable serial interface
  - · Data can be 7, 8 or 9 bits
  - · Even, odd and no-parity
  - 0.5, 1, 1.5 and 2 stop bits
  - Programmable data order with MSB or LSB first
  - · Programmable baudrate generator
  - Configurable oversampling method by 16 or by 8
- Supports RS-232 and RS-485 hardware flow control
- Dual clock domain allowing:
  - · UART functionality and wakeup from Stop 1 mode



Baudrate programming independent of PCLK changes

The USART is a fully programmable serial interface featuring programmable:

- data length,
- parity,
- number of stop bits,
- data order,
- baud rate generator

and configurable oversampling mode by 8 or by 16. You also have the option to use basic RS-232 flow control with CTS (Clear To Send) and RTS (Request To Send) signals.

The RS-485 DE (Driver Enable) signal is also supported. The USART supports a dual clock domain allowing wakeup from stop mode and baud rate programming independent of the peripheral clock (PCLK).

This also allows the peripheral clock to be throttled along with the core clock without disrupting communications.

# Key Features Continued —

- Multi-processor communication
- Single-wire half-duplex communication
- Auto-baudrate detection
- Receiver timeout feature
- Supports also
  - LIN mode
  - Synchronous mode (Master mode)
  - · IrDA SIR Encoder Decoder



- Smartcard (T=0, T=1)
- Basics to implement Modbus/RTU and Modbus/ASCII

The USART features a multi-processor mode which allows the USART to remain idle when it is not addressed.

In addition to full-duplex communication, single-wire halfduplex mode is also supported.

The USART also offers many other features including auto baud rate detection, receiver timeout and supports several modes which will be described later in the presentation.



This is the USART block diagram.

The USART clock (fCK) can be selected from several sources: system clock, peripheral clock (APB clock), the high-speed internal 16 MHz RC oscillator or the low-speed external 32.768 kHz crystal oscillator.

Tx and Rx are used for data transmission and reception. nCTS and nRTS are used for RS-232 hardware flow control.

The Driver Enable (DE) which is available on the same I/O as nRTS is used in RS-485 mode.

The clock output (SCLK) is dual purpose:

When the USART is used in Synchronous Master mode, the clock provided to the slave device is output on the SCLK pin.

When the USART is used in Smartcard mode, the clock provided to the card is output on the SCLK pin.

## Dual clock domain

### 6

### Baudrate programming independent from PCLK reprogramming

- Flexible clocking scheme through selectable clock sources
  - PCLK (default)
  - HSI16 clock
  - LSE clock
  - System clock (SYSCLK)
- Access to registers is always at peripheral bus speed.





The USART has a flexible clocking scheme. Its clock source can be selected in the RCC, and can be either the PCLK (peripheral clock), which is the default clock source, or the HSI16, LSE or System clock. The registers are accessed through the APB bus, and the kernel is clocked with fck which is independent from the APB clock.

# Oversampling

### Different user configurable oversampling techniques

Oversampling choice affects speed and framing tolerance:

|           | Oversampling by 8                                         | Oversampling by 16                                          |  |
|-----------|-----------------------------------------------------------|-------------------------------------------------------------|--|
| Benefits  | Achieve the maximum speed f <sub>CK</sub> /8              | Maximum receiver tolerance to clock deviation is increased. |  |
| Drawbacks | Maximum receiver tolerance to clock deviation is reduced. | Maximum speed is limited to f <sub>CK</sub> /16.            |  |

Maximum baudrate depends on selected clock and oversampling:
It is 10 Mbaud when clock source is at 80 MHz and Oversampling by 8 is configured.



The USART receiver implements different userconfigurable oversampling techniques for data recovery by discriminating between valid incoming data and noise. This allows a trade-off between the maximum communication speed and noise/clock inaccuracy immunity.

Select oversampling by 8 to achieve higher speed (up to f\_CLK/8) where f\_CLK is the USART clock source frequency. In this case the maximum receiver tolerance to clock deviation is reduced.

Select Oversampling by 16 (OVER8 = 0) to increase the tolerance of the receiver to clock deviations. In this case, the maximum speed is limited to f\_CLK/16.

The maximum baud rate that can be reached is 10 Mbaud when the clock source is at 80 MHz and Oversampling by 8 is configured.

With other clock sources, and/or higher oversampling ratio, the maximum speed is limited.



The frame format used in Asynchronous mode consists of a set of data bits in addition to bits for synchronization and optionally a parity bit for error checking.

The USART supports 7, 8 or 9-bit data lengths.

A frame starts with one start-bit, where the line is driven low for one bit-period. This signals the start of a frame, and is used for synchronization.

The start bit is followed by 7, 8 or 9 data bits. If Parity Control is enabled, the parity bit is transmitted as the last data bit and is included in the data length count.

Finally, a number of stop-bits (0, 1, 1.5 or 2), where the line is driven high, end the frame.



The standard frame was described in the previous slide. This slide shows an example of 8-bit data frames configured with 1 stop bit.

An Idle character is interpreted as an entire frame of "1"s. (The number of "1"s will include the number of stop bits).

A Break character is interpreted on receiving "0"s for a frame period. At the end of the break frame, 2 stop bits are inserted.

# Full/Half duplex modes ---

Full-duplex: Two wires Half-duplex: Single wire

- USART full-duplex communication:
  - Tx and Rx lines are respectively connected with the other interface's Rx and Tx lines.
- USART single-wire half-duplex protocol
  - · Tx and Rx lines are internally connected.
  - Tx pin is used for both transmission and reception.





The USART supports full-duplex communication where Tx and Rx lines are respectively connected with the other interface's Rx and Tx lines.

The USART can be configured to follow a single-wire half-duplex protocol where the Tx and Rx lines are internally connected.

In this communication mode, only the Tx pin is used for both transmission and reception.

The Tx pin is always released when no data is transmitted, thus, it acts as a standard I/O in idle or reception modes.

This means that the I/O must be configured so that Tx is configured as alternate function open-drain with an external pull-up.

### R32 hardS-2ware flow control

### Hardware handshaking to avoid data underrun/overrun

- RS-232 hardware flow control
  - nRTS (Request To Send) output asserted means that the receiver is ready to accept data.
  - nCTS (Clear To Send) input asserted means that transmitter can continue communication.
  - Particulary useful for half-duplex systems.





In RS-232 communication, it is possible to control the serial data flow between 2 devices by using the nCTS input and the nRTS output. These two lines allow the receiver and the transmitter to alert each other of their state. The following figure shows how to connect 2 devices in this mode. The idea is to prevent dropped bytes or conflicts in case of half-duplex communication. Both signals are active low.

## RS-485 hardware flow control -12

### Hardware handshaking

- Useful in a half-duplex system where the master needs to generate a direction signal to control the transceiver (Physical Layer (PHY)). This signal informs the PHY if it must act in send or receive mode.
- It uses the DE (Driver Enable) pin to activate the external RS-485 bus driver.
- The DE and nRTS signals are available on the same pin



For serial half-duplex communication protocols like RS-485, the master needs to generate a direction signal to control the transceiver (Physical Layer). This signal informs the Physical Layer if it must act in send or receive mode.

In RS-485 mode, a control line is used: the Driver Enable pin is used to activate the external transceiver control. DE shares the pin with nRTS.

## Multi-processor communication = 13

### Communication between several devices

- In multi-processor communication, it is desirable that only the intended message recipient should actively receive the message.
- The devices not being addressed are put into Mute mode.
- Mute mode can be controlled using two methods:
  - Idle line detection
  - · Address mark detection



To simplify communication between multiple processors, the USART supports a multi-processor mode. In multi-processor communication, it is desirable that only the intended message recipient should actively receive the message.

The devices not being addressed are put into Mute mode.

The USART can enter or exit from Mute mode using one of two methods:

- Idle line detection
- Address mark detection



The USART can also communicate synchronously. It can operate as a SPI in Master mode with programmable clock polarity (CPOL) and phase (CPHA). The clock is output on the SCLK pin. No clock pulses are provided during the start and stop bits.

### ISO/IEC 7816 mode = 15

### **USART interface for Smartcards and Security Access Module**

- Half-duplex mode
- Clock provided to Smartcard on SCLK pin.
- Programmable clock prescaler to guarantee a wide range of clock inputs
- ISO/IEC 7816 T=0 and T=1 protocols supported
- Both direct and inverse convention are available





The USART can be used in Smartcard mode, based on a half-duplex communication.

The clock is output to the Smartcard on the SCLK pin. It supports the T=0 protocol and provides many features allowing support for T=1.

Both direct and inverse conventions are supported directly by hardware.

### IrDA SIR Encoder Decoder -16 **USART** interface for infrared wireless connection · Half-duplex communication USART The data from and to the USART is represented in a NRZ (Non Return to IrDA\_OUT Transmit Zero) format Encoder For IrDA, the required format is RZI (Return to Zero Inverted) · The SIR Tx Encoder modulates the IrDA\_IN Receive Decoder signal before it leaves the USART. Similarly, the input signal is demodulated in the SIR Rx Decoder USART (NRZ) Max bit rate 115.2 Kbits/s The pulse width is 3/16 bit duration in normal mode

The USART supports IrDA specifications which is a half-duplex communication protocol.

The data from and to the USART is represented in a NRZ (Non Return to Zero) format where the signal value is at the same level through the entire bit period. For IrDA, the required format is RZI (Return to Zero Inverted) where a "1" is signaled by holding the line low, and a "0" is signaled by a short high pulse.

The SIR Transmit encoder modulates the Non Return to Zero (NRZ) transmit bit stream output from USART. The SIR receive decoder demodulates the return-to-zero bit stream from the infrared detector and outputs the received NRZ serial bit stream to the USART.

The USART only supports bit rates up to 115.2 Kbits/s for the SIR ENDEC.

In normal mode, the transmitted pulse width is specified

as 3/16 of a bit period.

## Auto baudrate detection -17

### Automatic baudrate configuration - UART receiver

- The USART is able to automatically determine the baudrate based on the reception of one character
- The received character can be:
  - · Any character starting with a bit at '1'
  - Any character starting with a 10xx pattern
  - 0x7F
  - 0x55





The USART receiver is able to detect and automatically configure the baudrate based on the reception of one character.

The received character can be a character starting with a bit at 1. In this case, the USART measures the duration of the start bit (falling edge to rising edge).

Any character starting with a 10xx pattern. In this case, the USART measures the duration of the start and of the 1st data bit. The duration is measured from falling edge to falling edge, ensuring better accuracy in the case of slow signal slopes.

0x7F character frame. In this case, the baudrate is updated first at the end of the start bit then at the end of the bit 6.

A 0x55 character frame. In this case, the baudrate is updated first at the end of the start bit, then at the end of bit and finally at the end of bit 6. In parallel, another

check is performed for each intermediate transition of RX line.

### Receiver timeout

 When the USART receiver doesn't receive new data for a programmed amount of time, this can be signaled to the application via a receiver timeout event.



- The USART receiver timeout counter starts counting:
  - From the end of the first stop bit in case of 1 and 1.5 stop bit configuration.
  - From the end of the second stop bit in case of 2 stop bits configuration.
  - From the beginning of the stop bit in case of 0.5 stop bit configuration.



The USART supports a receiver timeout feature. When the USART doesn't receive new data for a programmed amount of time, a receiver timeout event is signaled and an interrupt is generated if enabled.

The USART receiver timeout counter starts counting:

- From the end of the first stop bit in case of 1 and 1.5 stop bit configuration.
- From the end of the second stop bit in case of 2 stop bits configuration.
- From the beginning of the stop bit in case of 0.5 stop bit configuration.

# 

- The USART is able to wake up the MCU from Stop mode when the USART clock source is:
  - · HSI16 or
  - LSE
- The sources of wakeup can be:
  - · Standard RXNE interrupt or
  - · A specific wakeup event triggered by:
    - Start bit
    - · Address match
    - · Any received data



The USART is able to wake up the MCU from STOP mode when the USART clock source is the HSI16 or LSE clock.

The sources of wakeup can be a start bit, address match or any received data.

## Interrupts 20

| Interrupt event                 | Description                                                                                  |  |
|---------------------------------|----------------------------------------------------------------------------------------------|--|
| Transmit data register empty    | Set when the Transmit Data register is empty.                                                |  |
| Transmit complete               | Set when the data transmission is complete and both data and shift registers are empty.      |  |
| стѕ                             | Set when the nCTS input toggles.                                                             |  |
| Receive data register not empty | Set when the Receive Data register contains data.                                            |  |
| Idle line                       | Set when an idle line is detected.                                                           |  |
| Character match                 | Set when the received data corresponds to the programmed address.                            |  |
| Receiver timeout                | Set when there is no activity on the Rx line for a duration equal to the programmed timeout. |  |



### Several events can provide an interrupt:

- The Transmit Data Register Empty flag is set when the Transmit Data register is empty and ready to be written.
- The Transmit Complete flag is set when the data transmission is complete and both data and shift registers are empty.
- The CTS flag is set when the nCTS input toggles.
- The Receive Data Register Not Empty flag is set when the Receive Data register contains data ready to be read.
- The Idle Line flag is set when an idle line is detected.
- The Character Match flag is set when the received data corresponds to the programmed address.
- The Receiver Timeout flag is set when there is no activity on the Rx line for a programmed duration.

# Interrupts and DMA =21

| Interrupt event       | Description                             |  |
|-----------------------|-----------------------------------------|--|
| End of block          | Set when a complete block was received. |  |
| Wakeup from stop mode | Set when the wakeup event is verified.  |  |
| LIN break             | Set when a LIN break frame is detected. |  |

 DMA requests are triggered by Transmit data register empty and by Receive data register full.



The End of Block flag is set when a complete block is received.

The Wakeup from Stop Mode flag is set when the wakeup event is verified.

The DMA requests can be generated when Receive Buffer Not Empty or Transmit Buffer Empty flags are set.

## Error interrupts ====

| Interrupt event     | Description                                         |  |
|---------------------|-----------------------------------------------------|--|
| Overrun error       | Set when an overrun error occurs.                   |  |
| Parity error        | Set when a parity error occurs.                     |  |
| Framing error       | Set when a framing error occurs.                    |  |
| Noise error         | Set when a noise is detected on the received frame. |  |
| Auto-baudrate error | Set when the baudrate measurement failed.           |  |



### Several errors flags can be generated:

- The Overrun error flag is set when an overrun error occurs.
- The Parity error flag is set when a parity error occurs.
- The Framing error flag is set when a framing error occurs.
- The Noise error flag is set when a noise is detected on the received frame.
- The Auto-baudrate error flag is set when the baudrate measurement failed.

# Low-power modes 23

| Mode            | escription                                                                                                                                                                                                       |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Run             | Active.                                                                                                                                                                                                          |  |
| Sleep           | Active. Peripheral interrupts cause the device to exit Sleep mode.                                                                                                                                               |  |
| Low-power run   | Active.                                                                                                                                                                                                          |  |
| Low-power sleep | Active. Peripheral interrupts cause the device to exit Low-power sleep mode.                                                                                                                                     |  |
| Stop 0/Stop 1   | The USART is able to wake up the MCU from Stop 0/Stop 1 mode when the USART clock is set to HSI16 or LSE. The MCU can be woken up from Stop 0/Stop 1 mode using either a standard RXNE interrupt or a WUF event. |  |
| Stop 2          | Frozen. Peripheral registers content is kept.                                                                                                                                                                    |  |
| Standby         | Powered-down. The peripheral must be reinitialized after exiting Standby mode.                                                                                                                                   |  |
| Shutdown        | Powered-down. The peripheral must be reinitialized after exiting Shutdown mode.                                                                                                                                  |  |
|                 |                                                                                                                                                                                                                  |  |

The USART peripheral is active in Run and Low-power run, Sleep and Low-power sleep modes. The I2C interrupts cause the device to exit Sleep or Low-power sleep modes.

The USART is able to wake up the MCU from Stop 0 or Stop 1 mode when the USART clock is set to HSI16 or LSE. The MCU can be awaken from Stop 0 or Stop 1 mode using either a standard RXNE interrupt or a WUF event. In Stop 2, the device is not able to perform any communication. In Standby and Shutdown modes, the peripheral is in power-down, and it must be reinitialized after exiting Standby or Shutdown mode.

# STM32L4 USART instances features ==24

| USART features                              | USART1/2/3 | UART4/5 |
|---------------------------------------------|------------|---------|
| Hardware flow control for modem             | х          | x       |
| Multiprocessor communication                | x          | x       |
| Synchronous mode                            | х          | -       |
| Smartcard mode                              | x          | -       |
| Single wire half duplex communication       | x          | х       |
| IrDA SIR ENDEC                              | X          | x       |
| LIN mode                                    | x          | x       |
| Dual clock domain and wakeup from Stop mode | x          | x       |
| Receiver timeout                            | x          | x       |
| Modbus communication                        | х          | х       |
| Auto baudrate detection                     | х          | х       |
| Driver enable                               | x          | х       |

The STM32L4 devices embed five instances:

- USART1, 2 and 3 have a full set of features.
- Instances 4 and 5 do not support Synchronous and Smartcard modes

## Related peripherals =25

- Refer to these peripherals trainings linked to this peripheral
  - · GPIO (Alternate function configuration)
  - Reset and clock controller (RCC)
  - · Power controller (PWR)
  - Interrupts (NVIC and EXTI)
  - Direct memory access controller (DMA)



This is a list of peripherals related to the USART. Please refer to these peripheral trainings for more information if needed.

- General-purpose input/outputs
- Reset and clock controller
- Power controller
- Interrupts controller
- Direct memory access controller