

# Introduction to embedded programming on STM32

*Hello world!*

# Type of communication service

**Simplex**

**Duplex**

**Full-duplex**

**Half-duplex**

# Simplex communication

OR



# Half-duplex communication

**OR**



# Full-duplex communication



# Universal synchronous asynchronous receiver transmitter (USART). Main features

- Full-duplex asynchronous communications
- Baud rate of up to 6 Mbit/s
- Auto baud rate detection
- Programmable data word length (7, 8 or 9 bits)
- Programmable data order with MSB-first or LSB-first shifting
- Configurable stop bits (1 or 2 stop bits)
- Single-wire Half-duplex communications
- Continuous communications using DMA
- Swappable Tx/Rx pin configuration



# USART. Output waveform



# USART. Specific features

- Hardware flow control for modem
- Continuous communication using DMA
- Multiprocessor communication
- Synchronous mode
- Smartcard mode
- Single-wire Half-duplex communication
- IrDA SIR ENDEC block
- LIN mode
- Modbus communication
- Auto baud rate detection
- Receiver timeout interrupt

# USART. Hardware flow control



## USART. Full/half duplex modes



Full Duplex



Half Duplex

# USART. SPI mode



# USART. Smartcards



# USART. IrDA



# USART. Oversampling by 16



# USART. Oversampling by 8



# UART. Noise detection

| <b>Sampled value</b> | <b>NE status</b> | <b>Received bit value</b> |
|----------------------|------------------|---------------------------|
| 000                  | 0                | 0                         |
| 001                  | 1                | 0                         |
| 010                  | 1                | 0                         |
| 011                  | 1                | 1                         |
| 100                  | 1                | 0                         |
| 101                  | 1                | 1                         |
| 110                  | 1                | 1                         |
| 111                  | 0                | 1                         |

# USART. Baud rate generation

In case of oversampling by 16, the equation is:

$$\text{Tx/Rx baud} = \frac{f_{CK}}{\text{USARTDIV}}$$

In case of oversampling by 8, the equation is:

$$\text{Tx/Rx baud} = \frac{2 \times f_{CK}}{\text{USARTDIV}}$$

# USART. Baud rate generation

To obtain 9600 baud with f CK = 8 MHz.

In case of oversampling by 16:

$$\text{USARTDIV} = 8,000,000 / 9,600$$

$$\text{BRR} = \text{USARTDIV} = 833d = \text{0x341}$$

In case of oversampling by 8:

$$\text{USARTDIV} = 2 * 8,000,000 / 9,600$$

$$\text{USARTDIV} = 1,666.66 \quad (1,667d = 683h)$$

$$\text{BRR}[3:0] = 3h \gg 1 = 1h$$

$$\text{BRR} = \text{0x681}$$

# USART. USART baud rate generation

| Baud rate |            | Oversampling by 16 (OVER8 = 0) |        |                                                                  | Oversampling by 8 (OVER8 = 1) |        |         |
|-----------|------------|--------------------------------|--------|------------------------------------------------------------------|-------------------------------|--------|---------|
| S.No      | Desired    | Actual                         | BRR    | % Error =<br>(Calculated -<br>Desired)B.Rate /<br>Desired B.Rate | Actual                        | BRR    | % Error |
| 2         | 2.4 KBps   | 2.4 KBps                       | 0x4E20 | 0                                                                | 2.4 KBps                      | 0x9C40 | 0       |
| 3         | 9.6 KBps   | 9.6 KBps                       | 0x1388 | 0                                                                | 9.6 KBps                      | 0x2710 | 0       |
| 4         | 19.2 KBps  | 19.2 KBps                      | 0x9C4  | 0                                                                | 19.2 KBps                     | 0x1384 | 0       |
| 5         | 38.4 KBps  | 38.4 KBps                      | 0x4E2  | 0                                                                | 38.4 KBps                     | 0x9C2  | 0       |
| 6         | 57.6 KBps  | 57.62 KBps                     | 0x341  | 0.03                                                             | 57.59 KBps                    | 0x681  | 0.02    |
| 7         | 115.2 KBps | 115.11 KBps                    | 0x1A1  | 0.08                                                             | 115.25 KBps                   | 0x340  | 0.04    |
| 8         | 230.4 KBps | 230.76KBps                     | 0xD0   | 0.16                                                             | 230.21 KBps                   | 0x1A0  | 0.08    |
| 9         | 460.8 KBps | 461.54KBps                     | 0x68   | 0.16                                                             | 461.54KBps                    | 0xD0   | 0.16    |
| 10        | 921.6KBps  | 923.07KBps                     | 0x34   | 0.16                                                             | 923.07KBps                    | 0x64   | 0.16    |
| 11        | 2 MBps     | 2 MBps                         | 0x18   | 0                                                                | 2 MBps                        | 0x30   | 0       |
| 12        | 3 MBps     | 3 MBps                         | 0x10   | 0                                                                | 3 MBps                        | 0x20   | 0       |
| 13        | 4MBps      | N.A                            | N.A    | N.A                                                              | 4MBps                         | 0x14   | 0       |
| 14        | 5MBps      | N.A                            | N.A    | N.A                                                              | 5052.63KBps                   | 0x11   | 1.05    |
| 15        | 6MBps      | N.A                            | N.A    | N.A                                                              | 6MBps                         | 0x10   | 0       |

# USART. Parity control

| M bits | PCE bit | USART frame <sup>(1)</sup> |
|--------|---------|----------------------------|
| 00     | 0       | SB   8-bit data   STB      |
| 00     | 1       | SB   7-bit data   PB   STB |
| 01     | 0       | SB   9-bit data   STB      |
| 01     | 1       | SB   8-bit data   PB   STB |
| 10     | 0       | SB   7-bit data   STB      |
| 10     | 1       | SB   6-bit data   PB   STB |

1. Legends: SB: start bit, STB: stop bit, PB: parity bit. In the data register, the PB is always taking the MSB position (9th, 8th or 7th, depending on the M bits value).

# USART. Interrupts

| Interrupt event                                                           | Event flag         | Enable Control bit |
|---------------------------------------------------------------------------|--------------------|--------------------|
| Transmission Complete                                                     | TC                 | TCIE               |
| Receive data register not empty (data ready to be read)                   | RXNE               | RXNEIE             |
| Overrun error detected                                                    | ORE                |                    |
| Idle line detected                                                        | IDLE               | IDLEIE             |
| Parity error                                                              | PE                 | PEIE               |
| LIN break                                                                 | LBDF               | LBDIE              |
| Noise Flag, Overrun error and Framing Error in multibuffer communication. | NF or ORE or FE    | EIE                |
| Character match                                                           | CMF                | CMIE               |
| Receiver timeout                                                          | RTOF               | RTOIE              |
| End of Block                                                              | EOBF               | EOBIE              |
| Wakeup from Stop mode                                                     | WUF <sup>(1)</sup> | WUFIE              |



# USART. Registers

- **USART\_CR1**
- **USART\_CR2**
- **USART\_CR3**
- **USART\_BRR** - Baud rate register
- **USART\_GTPR** - Guard time and prescaler register
- **USART\_RTOR** - Receiver timeout register
- **USART\_RQR** - Request register
- **USART\_ISR** - Interrupt and status register
- **USART\_ICR** - Interrupt flag clear register
- **USART\_RDR** - Receive data register
- **USART\_TDR** - Transmit data register

# Killer-feature of USART

**Debug might become easier and PC-like**

*But we give no warranty*

# USART. Example

*Switch to example!*

# SPI. Serial peripheral interface

- Master or slave operation
- Full-duplex, half-duplex and simplex
- 4-bit to 16-bit data size selection
- Programmable clock polarity and phase
- NSS management by hardware or software



# SPI. Full-duplex



# SPI. Half-duplex



# SPI. Simplex



# SPI. Multi slave mode



# SPI. Multi master mode



# SPI. CPHA (clock phase) = 1



# SPI. CPHA (clock phase) = 0



# SPI, RX and TX FIFOs



# DMA. Main features

- Up to 7 independently configurable channels
- Priorities between requests from the DMA channels are software programmable
- Independent source and destination transfer size (byte, halfword, word)
- Support for circular buffer management
- 3 event flags (DMA Half Transfer, DMA Transfer complete and DMA Transfer Error)
- Memory-to-memory transfer
- Peripheral-to-memory and memory-to-peripheral, and peripheral-to-peripheral transfers
- Access to Flash, SRAM, APB and AHB peripherals as source and destination
- Programmable number of data to be transferred: up to 65535

# DMA. Diagram



# DMA transactions



**DMA\_CPARx, DMA\_CMARx and DMA\_CNDTRx**

# Arbiter

- The arbiter manages the channel requests based on their priority and launches the peripheral/memory access sequences
- Software: each channel priority can be configured in the DMA\_CCRx register. There are four levels:
  - Very high priority
  - High priority
  - Medium priority
  - Low priority
- Hardware: if 2 requests have the same software priority level, the channel with the lowest number will get priority versus the channel with the highest number.

# DMA. Channel configuration procedure

- Set the peripheral register address in the DMA\_CPARx register
- Set the memory address in the DMA\_CMARx register
- Configure the total number of data to be transferred in the DMA\_CNDTRx register
- Configure the channel priority using the PL[1:0] bits in the DMA\_CCRx register
- Configure data transfer direction, circular mode, peripheral & memory incremented mode, peripheral & memory data size, and interrupt after half and/or full transfer in the DMA\_CCRx register
- Activate the channel by setting the ENABLE bit in the DMA\_CCRx register

# DMA. Reminder of sizes

- When the DMA initiates an AHB byte or halfword write operation, the data are duplicated on the unused lanes of the HWDATA[31:0] bus
- To write the halfword “0xABCD”, the DMA sets the HWDATA bus to “0xABCDABCD” with HSIZE = HalfWord
- To write the byte “0xAB”, the DMA sets the HWDATA bus to “0xABABABAB” with HSIZE = Byte
- An AHB byte write operation of the data “0xB0” to 0x0 (or to 0x1, 0x2 or 0x3) will be converted to an APB word write operation of the data “0xB0B0B0B0” to 0x0
- An AHB halfword write operation of the data “0xB1B0” to 0x0 (or to 0x2) will be converted to an APB word write operation of the data “0xB1B0B1B0” to 0x0

# DMA. Error management

- Error can be generated by reading from or writing to a reserved address space
- Only it happens, the faulty channel is automatically disabled through a hardware clear of its EN bit in the corresponding Channel configuration register (DMA\_CCRx)
- The channel transfer error interrupt flag (TEIF) in the DMA\_IFR register is set and an interrupt is generated if the transfer error interrupt enable bit (TEIE) in the DMA\_CCRx register is set

# DMA. Interrupts

| <b>Interrupt event</b> | <b>Event flag</b> | <b>Enable control bit</b> |
|------------------------|-------------------|---------------------------|
| Half-transfer          | HTIF              | HTIE                      |
| Transfer complete      | TCIF              | TCIE                      |
| Transfer error         | TEIF              | TEIE                      |

# DMA. Be aware of limitations

*The hardware requests from the peripherals (TIMx, ADC, DAC, SPI, I2C, and USARTx) are simply logically ORed before entering the DMA. This means that on one channel, only one request must be enabled at a time.*

| Peripherals       | Channel 1                                           | Channel 2                                           | Channel 3                                           | Channel 4                                           | Channel 5                                        |
|-------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|--------------------------------------------------|
| <b>ADC</b>        | ADC <sup>(1)</sup>                                  | ADC <sup>(2)</sup>                                  | -                                                   | -                                                   | -                                                |
| <b>SPI</b>        | -                                                   | SPI1_RX                                             | SPI1_TX                                             | SPI2_RX                                             | SPI2_TX                                          |
| <b>USART</b>      | -                                                   | USART1_TX <sup>(1)</sup>                            | USART1_RX <sup>(1)</sup>                            | USART1_TX <sup>(2)</sup><br>USART2_TX               | USART1_RX <sup>(2)</sup><br>USART2_RX            |
| <b>I2C</b>        | -                                                   | I2C1_TX                                             | I2C1_RX                                             | I2C2_TX                                             | I2C2_RX                                          |
| <b>TIM1</b>       | -                                                   | TIM1_CH1                                            | TIM1_CH2                                            | TIM1_CH4<br>TIM1_TRIG<br>TIM1_COM                   | TIM1_CH3<br>TIM1_UP                              |
| <b>TIM2</b>       | TIM2_CH3                                            | TIM2_UP                                             | TIM2_CH2                                            | TIM2_CH4                                            | TIM2_CH1                                         |
| <b>TIM3</b>       | -                                                   | TIM3_CH3                                            | TIM3_CH4<br>TIM3_UP                                 | TIM3_CH1<br>TIM3_TRIG                               | -                                                |
| <b>TIM6 / DAC</b> | -                                                   | -                                                   | TIM6_UP<br>DAC_Channel1                             | -                                                   | -                                                |
| <b>TIM15</b>      | -                                                   | -                                                   | -                                                   | -                                                   | TIM15_CH1<br>TIM15_UP<br>TIM15_TRIG<br>TIM15_COM |
| <b>TIM16</b>      | -                                                   | -                                                   | TIM16_CH1 <sup>(1)</sup><br>TIM16_UP <sup>(1)</sup> | TIM16_CH1 <sup>(2)</sup><br>TIM16_UP <sup>(2)</sup> | -                                                |
| <b>TIM17</b>      | TIM17_CH1 <sup>(1)</sup><br>TIM17_UP <sup>(1)</sup> | TIM17_CH1 <sup>(2)</sup><br>TIM17_UP <sup>(2)</sup> | -                                                   | -                                                   | -                                                |

# DMA. Example

*Switch to example!*