Introduction

The universal synchronous asynchronous receiver transmitter (USART) and the low-power universal asynchronous receive transmitter (LPUART) feature advanced low-power mode functions, which allow receiving data properly even when the STM32xx Series MCU is in low-power mode and the APB clock is disabled.

In this document, STM32xx Series refer only to the product Series listed in Table 1.

Table 1. Applicable products

<table>
<thead>
<tr>
<th>Type</th>
<th>Product Series</th>
</tr>
</thead>
<tbody>
<tr>
<td>Microcontroller</td>
<td>STM32F0, STM32F3, STM32G0, STM32G4, STM32L0, STM32L4, STM32L4+, STM32L5 and STM32WB</td>
</tr>
</tbody>
</table>
Contents

1 General information ......................................................... 5

2 Low-power modes from which the STM32xx Series MCU can be woken up with the USART/LPUART 5

3 USART/LPUART wakeup features ........................................ 6
   3.1 Dual clock domain .................................................... 6
   3.2 USART/LPUART wakeup sources .................................... 6

4 How the USART/LPUART wakes up the STM32xx Series MCU from low-power mode when the HSI clock is OFF 7

5 How to determine the USART/LPUART baud rate that allows a correct wake up from low-power mode ............... 9
   5.1 USART/LPUART kernel clock switched ON in low-power mode .... 9
      5.1.1 HSI clock used as USART/LPUART clock source .............. 9
      5.1.2 LSE clock used as LPUART clock source ....................... 9
      5.1.3 LSE clock used as USART clock source ....................... 9
   5.2 USART/LPUART HSI kernel clock is OFF in low-power mode ...... 10

6 Conclusion ................................................................. 13

7 Revision history .......................................................... 14
List of tables

Table 1. Applicable products ................................................................. 1
Table 2. Low-power modes versus STM32xx Series .................................. 5
Table 3. Tolerance of the USART receiver when BRR[3:0] = 0000 .............. 10
Table 4. Tolerance of the USART receiver when BRR[3:0] ≠ 0000 .............. 10
Table 5. Tolerance of the LPUART receiver ............................................ 11
Table 6. Document revision history ....................................................... 14
List of figures

Figure 1.  Wakeup event verified (wakeup event = address match) .............................. 7
Figure 2.  Wakeup event not verified (wakeup event = address match) .......................... 8
1 General information

The STM32xx Series microcontrollers are Arm®-based devices.

2 Low-power modes from which the STM32xx Series MCU can be woken up with the USART/LPUART

The USART and the LPUART can wake up the STM32xx Series MCU from low-power mode. Table 2 gives a summary of the low-power modes depending on the MCU Series.

<table>
<thead>
<tr>
<th>Product Series</th>
<th>The USART can wake up the MCU from</th>
<th>The LPUART can wake up the MCU from</th>
</tr>
</thead>
<tbody>
<tr>
<td>STM32F0/F3</td>
<td>Stop mode (with main regulator in Run mode or in low-power mode)</td>
<td>N.A</td>
</tr>
<tr>
<td>STM32L0</td>
<td>Stop mode (with main regulator in Run mode or in low-power mode, range 1/2/3)</td>
<td>Stop mode (with main regulator in Run mode or in low-power mode, range 1/2/3)</td>
</tr>
</tbody>
</table>
| STM32L4/L4+/L5/ WB | Stop mode 0  
Stop mode 1 | Stop mode 0  
Stop mode 1  
Stop mode 2 |
| STM32G0/G4     | Stop mode 0  
Stop mode 1 | Stop mode 0  
Stop mode 1 |

For a detailed description of the above low-power modes, refer to the Power control section of the corresponding reference manual.

---

a. Arm is a registered trademark of Arm Limited (or its subsidiaries) in the US and/or elsewhere.
3  **USART/LPUART wakeup features**

3.1 **Dual clock domain**

The USART/LPUART is able to wake up the MCU from low-power mode only when the peripheral supports the dual clock domain. This means that the USART/LPUART can be clocked by a clock independent from the APB clock. This clock can be either the HSI or the LSE clock. The USART/LPUART is then able to receive data even if the USART/LPUART clock is disabled and the MCU is in low-power mode.

3.2 **USART/LPUART wakeup sources**

Different USART/LPUART wakeup sources are available to wake up the MCU from low-power mode:

- A specific event selected through the WUS bits field of the USART/LPUART_CR3 register.
  - 00: Wakeup on address match (as defined by ADD[7:0] and ADDM7 of USART/LPUART_CR2 register)
  - 01: Reserved.
  - 10: Wakeup on Start bit detection
  - 11: Wakeup each time data are received (i.e. RXNE set in USART/LPUART_ISR register)

When the wakeup event is verified, the WUF flag in the USART/LPUART_ISR register is set by hardware independently of whether the MCU is in low-power mode or in Run mode. It generates a wakeup interrupt if the corresponding interrupt enable bit (WUFIE) is set in the USART/LPUART_CR3 register.

- RXNE interrupt
  - The RXNE interrupt must be enabled by setting the RXNEIE bit in the USART/LPUART_CR1 register before entering low-power mode.

To enable the USART/LPUART to wake up the MCU from low-power mode, the UESM bit in the USART/LPUART_CR1 control register must be set prior to entering low-power mode.
4 How the USART/LPUART wakes up the STM32xx Series MCU from low-power mode when the HSI clock is OFF

If the STM32xx Series MCU is in low-power mode and the HSI clock that is used as the USART/LPUART kernel clock is switched OFF when a falling edge on the USART/LPUART receive line is detected, the USART/LPUART interface requests the HSI clock to be switched ON again. The HSI clock is then used for frame reception.

If the wakeup event is verified, the MCU wakes up from low-power mode and data reception goes on normally.

If the wakeup event is not verified, the HSI clock is switched OFF again, the MCU is not woken up and remains in low-power mode, and the kernel clock request is released. Figure 1 and Figure 2 show an example of wakeup event programmed to “address match detection”.

Figure 1. Wakeup event verified (wakeup event = address match)

1. Refer to Section 5.2 for details on tWUUSART and tWULPUART.
How the USART/LPUART wakes up the STM32xx Series MCU from low-power mode when the HSI

Figure 2. Wakeup event not verified (wakeup event = address match)

1. Refer to Section 5.2 for details on $t_{\text{WUSART}}$ and $t_{\text{WULPUART}}$. 
5 How to determine the USART/LPUART baud rate that allows a correct wake up from low-power mode

The maximum baud rate that allows waking up correctly from low-power mode depends on whether the kernel clock is switched ON or OFF when the STM32xx Series MCU is in low-power mode.

5.1 USART/LPUART kernel clock switched ON in low-power mode

If the USART/LPUART kernel clock is switched ON during low-power mode, there is no constraint on the maximum baud rate that allows waking up from low-power mode. It is the same as in Run mode.

5.1.1 HSI clock used as USART/LPUART clock source

In STM32L0/L4 Series, there are two ways to keep the HSI clock ON during low-power mode:

- Set the HSIKERON bit in the RCC_CR register.
- or set the UCESM bit in the USART/LPUART_CR3 register. This bit allows the USART/LPUART to request the clock all the time and not only on Start bit falling edge.

Note: The UCESM bit is not available in the STM32G0/G4/L4+/L5/WB Series. So, in these series, only setting the HSIKERON bit allows keeping the HSI ON during low-power mode.

This section is not valid for STM32F0/F3 Series where the HSI clock is always OFF during Stop mode and is switched ON only when a falling edge is detected on the USART/LPUART receive line.

5.1.2 LSE clock used as LPUART clock source

When the LSE clock is used as LPUART clock source, the maximum baud rate that can be reached is 9600 bauds.

The LSE clock remains ON in low-power mode but in the STM32L0/L4 Series it is not propagated to the LPUART if the LPUART does not request this kernel clock. To correctly receive data at 9600 baud during low-power mode, the UCESM bit must be set in the LPUART_CR3 register. This bit allows the LPUART to request the clock all the time not only on Start bit falling edge.

In the other STM32xx Series, the LSE clock remains ON in low-power mode and is propagated to the LPUART, so there is no constraint to receive data at 9600 bauds.

5.1.3 LSE clock used as USART clock source

When the LSE clock is used as USART clock source, the maximum baud rate that can be reached is 4096 bauds in case of oversampling by 8, and 2048 bauds in case of oversampling by 16.
5.2 USART/LPUART HSI kernel clock is OFF in low-power mode

If the HSI clock is switched OFF during low-power mode, the maximum baud rate allowing to correctly wake up the STM32xx Series MCU from low-power mode depends on the following criteria:

- The wakeup time parameter (*t*\textsubscript{WUUSART} or *t*\textsubscript{WULPUART})
  - In STM32F0/F3/L0 MCUs, *t*\textsubscript{WUUSART} (or *t*\textsubscript{WULPUART}) equals *t*\textsubscript{WUSTOP} as specified in the device datasheets.
  - In the other STM32xx Series, *t*\textsubscript{WUUSART} (or *t*\textsubscript{WULPUART}) is specified in the device datasheets.
- The USART receiver tolerance which in turn depends on the following parameters:
  - 9-, 10- or 11-bit character length configured through the M bits of the USART\_CR1 register
  - Oversampling by 8 or 16 configured through the OVER8 bit in the USART\_CR1 register
  - BRR[3:0] bits of USART\_BRR register equal to or different from 0000.
  - Use of one or three sample bits to sample data, depending on ONEBIT bit in the USART\_CR3 register

*Table 3* and *Table 4* summarize the USART receiver tolerance according to the values of the above parameters.

**Table 3. Tolerance of the USART receiver when BRR[3:0] = 0000**

<table>
<thead>
<tr>
<th>M bits</th>
<th>OVER8 bit = 0</th>
<th>OVER8 bit = 1</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>ONEBIT = 0</td>
<td>ONEBIT = 1</td>
</tr>
<tr>
<td>00</td>
<td>3.75 %</td>
<td>4.375 %</td>
</tr>
<tr>
<td>01</td>
<td>3.41 %</td>
<td>3.97 %</td>
</tr>
<tr>
<td>10</td>
<td>4.16 %</td>
<td>4.86 %</td>
</tr>
</tbody>
</table>

**Table 4. Tolerance of the USART receiver when BRR[3:0] ≠ 0000**

<table>
<thead>
<tr>
<th>M bits</th>
<th>OVER8 bit = 0</th>
<th>OVER8 bit = 1</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>ONEBIT = 0</td>
<td>ONEBIT = 1</td>
</tr>
<tr>
<td>00</td>
<td>3.33 %</td>
<td>3.88 %</td>
</tr>
<tr>
<td>01</td>
<td>3.03 %</td>
<td>3.53 %</td>
</tr>
<tr>
<td>10</td>
<td>3.7 %</td>
<td>4.31 %</td>
</tr>
</tbody>
</table>

- The LPUART receiver tolerance, which in turn depends on the following parameters:
  - Number of Stop bits configured through STOP[1:0] bits in the LPUART\_CR2 register.
  - LPUART\_BRR register value

*Table 5* summarizes the USART receiver tolerance according to the values of the above parameters.
**Table 5. Tolerance of the LPUART receiver**

<table>
<thead>
<tr>
<th>M bits</th>
<th>OVER8 bit = 0</th>
<th>OVER8 bit = 1</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>ONEBIT = 0</td>
<td>ONEBIT = 1</td>
</tr>
<tr>
<td>8 bits (M = 00), 1 Stop bit</td>
<td>1.82 %</td>
<td>2.56 %</td>
</tr>
<tr>
<td>9 bits (M = 01), 1 Stop bit</td>
<td>1.69 %</td>
<td>2.33 %</td>
</tr>
<tr>
<td>7 bits (M = 10), 1 Stop bit</td>
<td>2.08 %</td>
<td>2.86 %</td>
</tr>
<tr>
<td>8 bits (M = 00), 2 Stop bits</td>
<td>2.08 %</td>
<td>2.86 %</td>
</tr>
<tr>
<td>9 bits (M = 01), 2 Stop bits</td>
<td>1.82 %</td>
<td>2.56 %</td>
</tr>
<tr>
<td>7 bits (M = 10), 2 Stop bits</td>
<td>2.34 %</td>
<td>3.23 %</td>
</tr>
</tbody>
</table>

The USART/LPUART asynchronous receiver works correctly only if the total clock system deviation is less than the tolerance of the USART/LPUART receiver. The causes which contribute to the total deviation are:

- **DTRA:** deviation due to the transmitter error (which also includes the deviation of the transmitter local oscillator)
- **DQUANT:** error due to the baud rate quantization of the receiver
- **DREC:** deviation of the receiver local oscillator
- **DTCL:** deviation due to the transmission line (generally due to the transceivers which can introduce an asymmetry between the low-to-high transition timing and the high-to-low transition timing)

\[
DTRA + DQUANT + DREC + DTCL + DWU < \text{USART/LPUART receiver tolerance}
\]

where DWU is the is the error due to sampling point deviation when the wakeup from low-power mode is used.

The maximum baud rate that allows a correct wake up from low-power mode can be computed as follows:

- **Case of USART/LPUART receiver with 9-bit data length, M bits = 01**
  \[
  \text{DWU max} = \frac{t_{\text{WUUSART/WULPUART}}}{11 \times T_{\text{bit min}}}\]
  \[
  \text{Baud rate max} = \frac{(11 \times \text{DWU max})}{t_{\text{WUUSART/WULPUART}}}
  \]
  where \( T_{\text{bit Min}} \) is the minimum bit duration

- **Case of USART/LPUART receiver with 8-bit data length, M bits = 00**
  \[
  \text{DWU max} = \frac{t_{\text{WUUSART/WULPUART}}}{10 \times T_{\text{bit min}}}\]
  \[
  \text{Baud rate max} = \frac{(10 \times \text{DWU max})}{t_{\text{WUUSART/WULPUART}}}
  \]

- **Case of USART/LPUART receiver with 7-bit data length, M bits = 10**
  \[
  \text{DWU max} = \frac{t_{\text{WUUSART/WULPUART}}}{9 \times T_{\text{bit min}}}\]
  \[
  \text{Baud rate max} = \frac{(9 \times \text{DWU max})}{t_{\text{WUUSART/WULPUART}}}
  \]

**Example of an STM32L4 USART receiver with OVER8 = 0, M bits = 10, ONEBIT = 1 and BRR [3:0] = 0000.**

In these conditions, according to Table 3: Tolerance of the USART receiver when BRR[3:0] = 0000, the USART receiver tolerance is 4.86 %.
If we consider an ideal case where the DTRA, DQUANT, DREC and DTCL parameters are at 0%, DWU max is 4.86%.

In reality, we need to take into account at least the HSI inaccuracy.

Let us consider an HSI inaccuracy of 1 %, $t_{\text{WUUSART}} = 8.5 \, \mu s$ (for Stop mode 1/2)

$\text{DWU max} = 4.86 \% - 1 \% = 3.86 \%$

$T_{\text{bit min}} = 8.5 \, \mu s / (9 \times 3.86 \%) = 24.4 \, \mu s.$

In these conditions, the maximum baud rate allowing to wakeup correctly from low-power mode is

$1/23.31 \, \mu s = \sim 40 \text{ Kbauds}.$
6 Conclusion

This application note explains how the USART/LPUART wakes up the STM32xx Series MCU from Stop mode. It also provides guidelines to approximately determine the USART/LPUART maximum baud rate that allows a proper wakeup from low-power mode.
## Revision history

Table 6. Document revision history

<table>
<thead>
<tr>
<th>Date</th>
<th>Revision</th>
<th>Changes</th>
</tr>
</thead>
<tbody>
<tr>
<td>08-Mar-2017</td>
<td>1</td>
<td>Initial release.</td>
</tr>
<tr>
<td>17-Dec-2019</td>
<td>2</td>
<td>Updated microcontroller list in:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>– Title of the document</td>
</tr>
<tr>
<td></td>
<td></td>
<td>– Table 1: Applicable products</td>
</tr>
<tr>
<td></td>
<td></td>
<td>– Section 5.2: USART/LPUART HSI kernel clock is OFF in low-power mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Added Section 1: General information (Arm logo added)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated Table 2: Low-power modes versus STM32xx Series</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Updated Section 5.1.1: HSI clock used as USART/LPUART clock source and Section 5.1.2: LSE clock used as LPUART clock source</td>
</tr>
</tbody>
</table>
IMPORTANT NOTICE – PLEASE READ CAREFULLY

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers’ products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. For additional information about ST trademarks, please refer to www.st.com/trademarks. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2019 STMicroelectronics – All rights reserved