## Microcontroller

A microcontroller is composed of

- A microprocessor (A microprocessor on it's own doesn't have peripherals)
- Flash memory and RAM
- Peripheral port/devices

Basically, a microcontroller is a microprocessor augmented by certain other components that allow it to control specific external portions of the system (e.g. external devices, sensors, actuators, etc.)

#### It's usages include

- For specific control or group of control over a system
- In industry machinery
- Vehicle and autonomous vehicle, robot, IoT, aircraft, bus, train, home management

In this course we focus mainly on the Nucleo-STM32F446re Cortex-M4 microcontroller. It's features include

- ARMv7 Architecture
- 32-bit Cortex-M4 processor with FPU, 180 MHz, DSP
- Harvard Bus Matrix
- Memory: 512 Kbytes Flash Memory
- 128 Kbytes SRAM
- $3 \times 12$  bit ADC up to 24 Channels
- 2 × 12 bit DAC
- 16-Channel General purpose DMA
- 17-timers
- Debug Mode SWD and JTAG

- 4-I2C.
- 6-USART (two UART)
- 4-SPI
- 2-SAI (Serial Audio Interface)
- 2-CAN
- SDIO, USB 2.0
- 8 to 14-bit camera interface up to 54 Mbytes/2
- CRC calculation unit
- RTC: SubSecond Accuracy
- 96-bit Unique ID

### Peripherals vs Ports vs Pins

- **Peripherals** are parts of the device that serve a specific purpose which help the microcontroller achieve a certain task. Some common microcontroller peripherals are Timers, Analog to Digital converters (ADC), Serial Peripheral Interfaces (SPI), Pulse Width Modulation and 2 wire interfaces (I2C).
- Ports provide direct access to the CPU and provide direct input/output to and from the CPU

• **Pins** are physical connections on a microcontroller board and may be connected to a bus through one or more ports/peripherals

The CPU is connected to these peripherals through buses collectively called the peripheral bus matrix

## Peripherals

A peripheral can be generally described as a port **(not literally a MCU port)** or terminal to communicate with the outside world. Its input and output can be both analog and digital. Speed of communication may vary for data transmission and reversion, and can be asynchronous (UART) or synchronous (SPI, I2C)

Analog input is taken using ADC, and analog output using DAC. Peripherals are an autonomous component, and are memory mapped or I/O mapped. Generally not functioning if electrically isolated from the system. In many cases, it is needed to configure the supply clock and power before enabling, as well as the mode of operation, type of input/output, and (if needed) Baud rate or speed of communication

Microprocessor can access the peripheral directly and configure using memory mapped I/O or I/O mapped I/O

## Memory Mapped I/O

Peripherals and I/O devices share memory space with the RAM. Same instructions (register to/from memory) are used to transfer data to I/O.

[Meaning the memory needed for Peripherals and I/O devices is in the RAM, and the processor can just write to those locations to directly configure the peripherals]

## I/O Mapped I/O

Separate memory address (not in the RAM), and one address line to enable or disable I/O or memory. Special instructions required to modify these memory (in/out in Intel), and send '1' to activate I/O and disable memory

# Clock Configuration (System Clock)

## Necessary Registers (along with descriptions of used bits)

## RCC Control Register (RCC\_CR)

| 31   | 30   | 29            | 28           | 27            | 26           | 25         | 24        | 23   | 22   | 21       | 20   | 19        | 18         | 17         | 16        |
|------|------|---------------|--------------|---------------|--------------|------------|-----------|------|------|----------|------|-----------|------------|------------|-----------|
| Res. | Res. | PLLSAI<br>RDY | PLLSAI<br>ON | PLLI2S<br>RDY | PLLI2S<br>ON | PLL<br>RDY | PLL<br>ON | Res. | Res. | Res.     | Res. | CSS<br>ON | HSE<br>BYP | HSE<br>RDY | HSE<br>ON |
|      |      | r             | rw           | r             | rw           | r          | rw        |      |      |          |      | rw        | rw         | r          | rw        |
| 15   | 14   | 13            | 12           | 11            | 10           | 9          | 8         | 7    | 6    | 5        | 4    | 3         | 2          | 1          | 0         |
|      |      |               | HSICA        | \L[7:0]       |              |            |           |      | H    | SITRIM[4 | :0]  |           | Res.       | HSI<br>RDY | HSI<br>ON |
| r    | r    | r             | r            | r             | r            | r          | r         | rw   | rw   | rw       | rw   | rw        |            | r          | rw        |

## RCC Clock Configuration Register (RCC\_CFGR)

| 31  | 30       | 29 | 28      | 27       | 26 | 25      | 24   | 23   | 22   | 21    | 20 | 19  | 18      | 17  | 16    |
|-----|----------|----|---------|----------|----|---------|------|------|------|-------|----|-----|---------|-----|-------|
| МСО | 2[1:0]   | МС | 02 PRE[ | 2:0]     | MC | 01 PRE[ | 2:0] | Res. | МС   | 01    |    | R   | TCPRE[4 | :0] |       |
| rw  |          | rw | rw      | rw       | rw | rw      | rw   |      | rw   |       | rw | rw  | rw      | rw  | rw    |
| 15  | 14       | 13 | 12      | 11       | 10 | 9       | 8    | 7    | 6    | 5     | 4  | 3   | 2       | 1   | 0     |
| F   | PRE2[2:0 | 0] | F       | PRE1[2:0 | )] | Res.    | Res. |      | HPRE | [3:0] |    | SWS | [1:0]   | SWI | [1:0} |
| rw  | rw       | rw | rw      | rw       | rw |         |      | rw   | rw   | rw    | rw | r   | r       | rw  | rw    |

## RCC PLL Configuration Register (RCC\_PLLCFGR)

|   | 31   | 30 | 29        | 28 | 27 | 26       | 25     | 24 | 23   | 22     | 21   | 20   | 19   | 18     | 17   | 16     |
|---|------|----|-----------|----|----|----------|--------|----|------|--------|------|------|------|--------|------|--------|
| F | Res. |    | PLLR[2:0] | ]  |    | PLLC     | 2[3:0] |    | Res. | PLLSRC | Res. | Res. | Res. | Res.   | PLLF | P[1:0] |
|   |      | rw | rw        | rw | rw | rw       | rw     | rw |      | rw     |      |      |      |        | rw   | rw     |
|   | 15   | 14 | 13        | 12 | 11 | 10       | 9      | 8  | 7    | 6      | 5    | 4    | 3    | 2      | 1    | 0      |
| F | Res. |    |           |    |    | PLLN[8:0 | ]      |    |      |        |      |      | PLLN | Λ[5:0] |      |        |
|   |      | rw | rw        | rw | rw | rw       | rw     | rw | rw   | rw     | rw   | rw   | rw   | rw     | rw   | rw     |

## RCC APB1 peripheral clock enable register (RCC\_APB1ENR)

| 31         | 30         | 29        | 28        | 27         | 26         | 25         | 24            | 23          | 22          | 21         | 20          | 19          | 18           | 17           | 16            |
|------------|------------|-----------|-----------|------------|------------|------------|---------------|-------------|-------------|------------|-------------|-------------|--------------|--------------|---------------|
| Res.       | Res.       | DAC<br>EN | PWR<br>EN | CEC<br>EN  | CAN2<br>EN | CAN1<br>EN | FMPI2C1<br>EN | I2C3<br>EN  | I2C2<br>EN  | I2C1<br>EN | UART5<br>EN | UART4<br>EN | USART3<br>EN | USART2<br>EN | SPDIFRX<br>EN |
|            |            | rw        | rw        | rw         | rw         | rw         | rw            | rw          | rw          | rw         | rw          | rw          | rw           | rw           | rw            |
| 15         | 14         | 13        | 12        | 11         | 10         | 9          | 8             | 7           | 6           | 5          | 4           | 3           | 2            | 1            | 0             |
| SPI3<br>EN | SPI2<br>EN | Res.      | Res.      | WWDG<br>EN | Res.       | Res.       | TIM14<br>EN   | TIM13<br>EN | TIM12<br>EN | TIM7<br>EN | TIM6<br>EN  | TIM5<br>EN  | TIM4<br>EN   | TIM3<br>EN   | TIM2<br>EN    |
| rw         | rw         |           |           | rw         |            |            | rw            | rw          | rw          | rw         | rw          | rw          | rw           | rw           | rw            |

#### PWR Power Control Register (PWR\_CR)

| 31   | 30     | 29     | 28   | 27    | 26    | 25   | 24   | 23   | 22      | 21    | 20    | 19   | 18     | 17     | 16   |
|------|--------|--------|------|-------|-------|------|------|------|---------|-------|-------|------|--------|--------|------|
| Res. | Res.   | Res.   | Res. | Res.  | Res.  | Res. | Res. | Res. | Res.    | FISSR | FMSSR | UDE  | N[1:0] | ODSWEN | ODEN |
|      |        |        |      |       |       |      |      |      |         | rw    | rw    | rw   | rw     | rw     | rw   |
| 15   | 14     | 13     | 12   | 11    | 10    | 9    | 8    | 7    | 6       | 5     | 4     | 3    | 2      | 1      | 0    |
|      |        |        |      |       |       |      | -    |      | •       | •     |       | •    | -      |        | •    |
| VOS  | S[1:0] | ADCDC1 | Res. | MRUDS | LPUDS | FPDS | DBP  |      | PLS[2:0 |       | PVDE  | CSBF | CWUF   | PDDS   | LPDS |

#### Procedure

- 1. Choose the source of the clock, from the following sources
  - a. HSI High Speed Internal Crystal
  - b. HSE High Speed External Crystal (8 MHz for F446)
- 2. Enable chosen crystal and wait for it to become ready (in RCC\_CR, HSE/HSI ON, wait for HSE/HSI RDY)
- 3. Next we need to provide power to the clock and peripherals, by enabling the power interface (in RCC\_APB1ENR, PWREN) and then manipulating the main internal voltage regulator output voltage (in PWR\_CR, VOS [we set it to 11])
- 4. Configure the flash memory and flash latency (using the FLASH\_ACR)
- 5. Configure the prescalars for the buses (AHB1, APB1, APB2 bus) by configuring their values in the configuration register (in RCC CFGR, HPRE, PPRE1, PPRE2)
- 6. Now choose whether to use the clock directly or use PLL or Phase Lock Loop, if using clock directly, skip these next two steps (skip to step 9)
- 7. Configure the main PLL, by using the 3 PLL prescalars M, N, P (divide, multiply, divide) (in RCC\_PLLCFGR, using PLL\_M, PLL\_N, and PLL\_P) and configuring the source of the PLL to be the initially chosen crystal (HSI or HSE) (in RCC\_PLLCFGR, using PLLSRC)
- 8. Enabling the PLL and waiting for it to become ready (in RCC\_CR, PLL ON, wait for PLL RDY)
- 9. Select the clock source (either HSE, HSI or PLL) and wait for it to become ready (in RCC\_CFGR, using SW, wait for SWS)

## **GPIO**

Input/Output pins are the entrances of the microprocessor to communicate with the outside world.

- Analog In/Out Communication
- Digital In/Out communication

GPIO pins are connected to the processor through GPIO ports (A...H) and each can be configured to one of 4 modes

- Input
- General Purpose Output
- Alternate Function Mode
- Analog Mode

#### Input states:

- floating (Input + no PUPD)
- pull-up/pull-down (Input + PU/PD)
- analog (Analog)

#### **Output states:**

- push-pull(Output + PushPull)
- open drain + pull-up/down (Output + Open Drain + PU/PD)

#### Push-Pull



In push pull output mode, when a signal of 1 is received (e.g. when the ODR bit corresponding to this GPIO pin is set to 1), the upper PMOS transistor allows the passage of current (NMOS is inactive) and thus, there is an output of VCC. Conversely, when a signal of 0 is received, the lower NMOS transistor is active and the PMOS is inactive, thus pulling the output to ground.



Here we show, output in Push-Pull mode, and ground in Push-Pull mode

## Open Drain

# Open Drain



In open drain, when a signal of 0 is received, the output is pulled to ground, and when a signal of 1 is received, output is floating (no VCC or ground, in fact no connection at all).

Floating state is also a possibility during input (if no connection is provided to the pin). As this is undesirable for General Purpose I/O (might be used for other cases), open drain (as well as input) is used in conjunction with a pull-up or pull-down resistor (whether internal or external)

### Pull-Up



Internal Pull-Up can be configured within the processor by manipulating relevant registers **(GPIOx\_PUPDR).** Using this resistor, we can ensure that when a signal of 1 is received, an output of VCC is obtained.

#### Pull-Down



Pull-Down is the same but with the resistor being connected to ground. This isn't particularly useful for output, as both 1 and 0 will provide an output of ground, but it will pull floating inputs to ground.

## Necessary Registers (along with descriptions of used bits)

## GPIO port mode register (GPIOx\_MODER)

| 31    | 30       | 29    | 28       | 27    | 26       | 25    | 24       | 23   | 22       | 21    | 20       | 19   | 18      | 17   | 16      |
|-------|----------|-------|----------|-------|----------|-------|----------|------|----------|-------|----------|------|---------|------|---------|
| MODER | R15[1:0] | MODER | R14[1:0] | MODER | R13[1:0] | MODER | R12[1:0] | MODE | R11[1:0] | MODER | R10[1:0] | MODE | R9[1:0] | MODE | R8[1:0] |
| rw    | rw       | rw    | rw       | rw    | rw       | rw    | rw       | rw   | rw       | rw    | rw       | rw   | rw      | rw   | rw      |
| 15    | 14       | 13    | 12       | 11    | 10       | 9     | 8        | 7    | 6        | 5     | 4        | 3    | 2       | 1    | 0       |
| MODE  | R7[1:0]  | MODE  | R6[1:0]  | MODE  | R5[1:0]  | MODE  | R4[1:0]  | MODE | R3[1:0]  | MODE  | R2[1:0]  | MODE | R1[1:0] | MODE | R0[1:0] |
| rw    | rw       | rw    | rw       | rw    | rw       | rw    | rw       | rw   | rw       | rw    | rw       | rw   | rw      | rw   | rw      |

## GPIO port output type register (GPIOx\_OTYPER)

| 31 | 30           | 29 | 28           | 27 | 26           | 25          | 24           | 23          | 22           | 21           | 20           | 19          | 18          | 17         | 16          |
|----|--------------|----|--------------|----|--------------|-------------|--------------|-------------|--------------|--------------|--------------|-------------|-------------|------------|-------------|
|    | EDR15<br>:0] |    | EDR14<br>:0] |    | EDR13<br>:0] |             | EDR12<br>:0] |             | EDR11<br>:0] | OSPEI<br>[1: | EDR10<br>:0] |             | EDR9<br>:0] |            | EDR8<br>:0] |
| rw | rw           | rw | rw           | rw | rw           | rw          | rw           | rw          | rw           | rw           | rw           | rw          | rw          | rw         | rw          |
| 15 | 14           | 13 | 12           | 11 | 10           | 9           | 8            | 7           | 6            | 5            | . 4          | 3           | 2           | 1          | 0           |
|    | EDR7<br>:0]  |    |              |    |              | EDR4<br>:0] |              | EDR3[<br>0] | OSPE<br>[1:  | EDR2<br>:0]  |              | EDR1<br>:0] |             | EDR0<br>0] |             |
| rw | rw           | rw | rw           | rw | rw           | rw          | rw           | rw          | rw           | rw           | rw           | rw          | rw          | rw         | rw          |

## GPIO port output speed register (GPIOx\_OSPEEDR)

| 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| Res. |
|      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| OT15 | OT14 | OT13 | OT12 | OT11 | OT10 | ОТ9  | OT8  | OT7  | ОТ6  | OT5  | OT4  | OT3  | OT2  | OT1  | ОТ0  |
| rw   |

## GPIO port pull-up/pull-down register (GPIOx\_PUPDR)

| 31    | 30       | 29    | 28       | 27    | 26       | 25    | 24       | 23    | 22       | 21    | 20       | 19    | 18      | 17    | 16      |
|-------|----------|-------|----------|-------|----------|-------|----------|-------|----------|-------|----------|-------|---------|-------|---------|
| PUPDE | R15[1:0] | PUPDF | R14[1:0] | PUPDR | R13[1:0] | PUPDR | R12[1:0] | PUPDF | R11[1:0] | PUPDR | R10[1:0] | PUPDI | R9[1:0] | PUPDI | R8[1:0] |
| rw    | rw       | rw    | rw      | rw    | rw      |
| 15    | 14       | 13    | 12       | 11    | 10       | 9     | 8        | 7     | 6        | 5     | 4        | 3     | 2       | 1     | 0       |
| PUPD  | R7[1:0]  | PUPDI | R6[1:0]  | PUPD  | R5[1:0]  | PUPD  | R4[1:0]  | PUPDI | R3[1:0]  | PUPDI | R2[1:0]  | PUPDI | R1[1:0] | PUPDI | R0[1:0] |
| rw    | rw       | rw    | rw      | rw    | rw      |

## GPIO port input data register (GPIOx\_IDR)

| 31          | 30          | 29   | 28          | 27          | 26          | 25        | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-------------|-------------|------|-------------|-------------|-------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Res.        | Res.        | Res. | Res.        | Res.        | Res.        | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      |
|             |             |      |             |             |             |           |           |           |           |           |           |           |           |           |           |
|             |             |      |             |             |             |           |           |           |           |           |           |           |           |           |           |
| 15          | 14          | 13   | 12          | 11          | 10          | 9         | 8         | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| 15<br>IDR15 | 14<br>IDR14 |      | 12<br>IDR12 | 11<br>IDR11 | 10<br>IDR10 | 9<br>IDR9 | 8<br>IDR8 | 7<br>IDR7 | 6<br>IDR6 | 5<br>IDR5 | 4<br>IDR4 | 3<br>IDR3 | 2<br>IDR2 | 1<br>IDR1 | 0<br>IDR0 |

## GPIO port output data register (GPIOx\_ODR)

| 31          | 30   | 29   | 28          | 27          | 26          | 25   | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-------------|------|------|-------------|-------------|-------------|------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Res.        | Res. | Res. | Res.        | Res.        | Res.        | Res. | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      | Res.      |
|             |      |      |             |             |             |      |           |           |           |           |           |           |           |           |           |
|             |      |      |             |             |             |      |           |           |           |           |           |           |           |           |           |
| 15          | 14   | 13   | 12          | 11          | 10          | 9    | 8         | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| 15<br>ODR15 |      |      | 12<br>ODR12 | 11<br>ODR11 | 10<br>ODR10 | _    | 8<br>ODR8 | 7<br>ODR7 | 6<br>ODR6 | 5<br>ODR5 | 4<br>ODR4 | 3<br>ODR3 | 2<br>ODR2 | 1<br>ODR1 | 0<br>ODR0 |

## GPIO port bit set/reset register (GPIOx\_BSRR)

| 3  | 1  | 30   | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|----|----|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| BR | 15 | BR14 | BR13 | BR12 | BR11 | BR10 | BR9 | BR8 | BR7 | BR6 | BR5 | BR4 | BR3 | BR2 | BR1 | BR0 |
| w  | /  | w    | w    | w    | w    | w    | w   | w   | w   | w   | w   | w   | w   | w   | w   | w   |
| 15 | 5  | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| BS | 15 | BS14 | BS13 | BS12 | BS11 | BS10 | BS9 | BS8 | BS7 | BS6 | BS5 | BS4 | BS3 | BS2 | BS1 | BS0 |
| W  | /  | w    | w    | W    | W    | W    | w   | w   | w   | w   | w   | w   | w   | w   | w   | w   |

#### Procedure

- 1. Choose the pin(s) you will be using for GPIO (e.g. PA\_5)
- 2. Enable the GPIO port to which the pin is connected from the AHB1 bus (in RCC\_AHB1ENR, GPIOXEN)
- 3. Configure the mode in which the pin will be used, input, output, alternate function or analog (in GPIOx\_MODER, for the particular pin)
- 4. [for output mode] Configure the output type, push-pull or open drain (in GPIOx\_OTYPER, for the particular pin)
- 5. [for output mode] Configure the output speed (in GPIOx\_OSPEEDR, for the particular pin)
- 6. Configure pull-up or pull-down mode, which will enable the internal pull-up or pull-down resistors (in GPIOx\_PUPDR, for the particular pin)
- 7. Now use the pin in the selected mode as follows:
  - a. Input Mode: Read the input data register to see if the pin is getting input (GPIOx\_IDR, for the particular pin)
  - b. Output Mode: Write 1 to the output data register to create an output in that particular pin (GPIOx\_ODR, for the particular pin). Alternatively, write to the binary set reset register to set the pin's output, and reset it respectively (GPIOx\_BSRR, writing to the set bit corresponding to a pin generates output, and writing to the reset bit clears it)

## Timer

Timers in microcontrollers are usually a counter of an oscillator clock, or clock counter. That is, it counts clock pulses. It uses the frequency of the internal clock and generates a delay and operates by incrementing a value in every machine cycle. After a configurable number of counts, it resets and begins counting from zero.

There are a number of different timers, with different capabilities:

- Advanced Control
- General Purpose
- Basic

| Timer<br>type        | Timer           | Counter resolution | Counter<br>type         | Prescaler<br>factor                   | DMA<br>request<br>generation | Capture/<br>compare<br>channels | Complementary output | Max<br>interface<br>clock<br>(MHz) | Max<br>timer<br>clock<br>(MHz) <sup>(1)</sup> |
|----------------------|-----------------|--------------------|-------------------------|---------------------------------------|------------------------------|---------------------------------|----------------------|------------------------------------|-----------------------------------------------|
| Advanced-<br>control | TIM1,<br>TIM8   | 16-bit             | Up,<br>Down,<br>Up/down | Any integer<br>between 1<br>and 65536 | Yes                          | 4                               | Yes                  | 90                                 | 180                                           |
|                      | TIM2,<br>TIM5   | 32-bit             | Up,<br>Down,<br>Up/down | Any integer<br>between 1<br>and 65536 | Yes                          | 4                               | No                   | 45                                 | 90/180                                        |
|                      | TIM3,<br>TIM4   | 16-bit             | Up,<br>Down,<br>Up/down | Any integer<br>between 1<br>and 65536 | Yes                          | 4                               | No                   | 45                                 | 90/180                                        |
| General              | TIM9            | 16-bit             | Up                      | Any integer<br>between 1<br>and 65536 | No                           | 2                               | No                   | 90                                 | 180                                           |
| purpose              | TIM10,<br>TIM11 | 16-bit             | Up                      | Any integer<br>between 1<br>and 65536 | No                           | 1                               | No                   | 90                                 | 180                                           |
|                      | TIM12           | 16-bit             | Up                      | Any integer<br>between 1<br>and 65536 | No                           | 2                               | No                   | 45                                 | 90/180                                        |
|                      | TIM13,<br>TIM14 | 16-bit             | Up                      | Any integer<br>between 1<br>and 65536 | No                           | 1                               | No                   | 45                                 | 90/180                                        |
| Basic                | TIM6,<br>TIM7   | 16-bit             | Up                      | Any integer<br>between 1<br>and 65536 | Yes                          | 0                               | No                   | 45                                 | 90/180                                        |

We will be focusing on the basic timers, TIM6 and TIM7 who are capable of DMA request generation (or in other words, capable of generating an interrupt). The other timers are capable of more advanced functions like generating PWM, etc. which can be seen above..

## Necessary Registers (along with descriptions of used bits)

## TIMx Control Register 1 (TIMx\_CR1)

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3   | 2   | 1    | 0   |
|------|------|------|------|------|------|------|------|------|------|------|------|-----|-----|------|-----|
| Res. | ARPE | Res. | Res. | Res. | OPM | URS | UDIS | CEN |
|      |      |      |      |      |      |      |      | rw   |      |      |      | rw  | rw  | rw   | rw  |

## TIMx Prescalar (TIMx\_PSC)

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|-----|--------|----|----|----|----|----|----|----|
| Γ |    |    |    |    |    |    |    | PSC | [15:0] |    |    |    |    |    |    |    |
| İ | rw  | rw     | rw | rw | rw | rw | rw | rw | rw |

The counter clock frequency CK\_CNT is equal to  $f_{CK-PSC}$  / (PSC[15:0] + 1).

## TIMx Auto-reload Register (TIMx\_ARR)

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|-----|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | ARR | [15:0] |    |    |    |    |    |    |    |
| rw | rw | rw | rw | rw | rw | rw | rw  | rw     | rw | rw | ΓW | rw | rw | rw | rw |

### TIMx Status Register (TIMx\_SR)

|   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0     |
|---|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-------|
| F | Res. | UIF   |
|   |      |      |      |      |      |      |      |      |      |      |      |      |      |      | rc_w0 |

### TIMx Counter (TIMx\_CNT)

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|-----|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | CNT | [15:0] |    |    |    |    |    |    |    |
| rw | rw | rw | rw | rw | rw | rw | rw  | rw     | rw | rw | rw | rw | rw | rw | rw |

## TIMx DMA/Interrupt Enable Register (TIMx\_DIER)

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8   | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0   |
|------|------|------|------|------|------|------|-----|------|------|------|------|------|------|------|-----|
| Res. | Res. | Res. | Res. | Res. | Res. | Res. | UDE | Res. | UIE |
|      |      |      |      |      |      |      | rw  |      |      |      |      |      |      |      | rw  |

## Procedure

- 1. Choose the desired minimum time delay or the unit for the timer.
- 2. Enable the timer and provide it with clock (using RCC\_APBXENR, TIMXEN)
- 3. Set the prescalar in order to get the desired delay (e.g if a delay of 1  $\mu$ S is desired, and the clock of the APB bus is 90 MHz, the prescalar should be 89 as 90/(89+1) = 1 MHz and delay will be 1/1 MHz = 1  $\mu$ S) (using TIMx\_PSC)
- 4. Set the **auto-reload register** for the maximum value the timer should count to **(using TIMx\_ARR)**
- 5. Enable or turn on the counter (by using TIMx\_CR1, CEN) and wait for it to be active (using TIMx\_SR, UIF)
- 6. Now in order to count to a certain value (i.e. generate a certain delay), set the count to 0 and wait for the count to reach the desired value (using TIMx\_CNT)
- 7. [Optional additional steps] Have the AR be preloaded by **using TIMx\_CR1, ARPRE**, and enable the interrupt/DMA by **using TIMx\_DIER**, **UIE and UDE**

### **UART**

**N.B.** We are focusing on UART here but it is simple enough to convert to USART by sending a clock from master to slave

Universal Asynchronous Receiver Transmitter. It is a serial, two-wire communication protocol in which data format & transmission speed are configurable. UART can be simplex, half duplex and full duplex, and can provide basic error detection using an optional parity bit.

By serial communication we mean that a single bit is transmitted at a time, and thus sending data through a single channel bit by bit sequentially. It is character oriented, that is data is sent one word at a time.

By asynchronous we mean that no clock signal is sent by the master to the slave for synchronization. Data transmission and reception between devices is done without synchronization, by using the following two mechanisms

- Both the devices must agree on timing parameters, by setting the baud rate
- By using two special bits at the start and end of each byte, namely the start and stop bits

In UART, the TX of the sender is connected to the RX of the receiver and vice versa, and both are connected to common ground.

## Disadvantages of UART

- UART doesn't support multiple slave or multiple master systems.
- Communication is limited by baud rate of the device with the lesser baud rate, and this limited speed is a bottleneck for data transmission.
- The maximum size of a data frame is limited.

#### **Baud Rate**

Baud rate is the measure of the speed of data transfer, expressed in bits per second (bps). Both devices participating in UART communication need to have exactly the same baud rate.

#### Configuration of Baud Rate

#### Equation 1: Baud rate for standard USART (SPI mode included)

$$Tx/Rx \text{ baud } = \frac{f_{CK}}{8 \times (2 - OVER8) \times USARTDIV}$$

#### Equation 2: Baud rate in Smartcard, LIN and IrDA modes

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

Here, USARTDIV is calculated from the DIV\_Mantissa and DIV\_Fraction in USART\_BRR. DIV\_Mantissa is simply converted to decimal, while DIV\_Fraction is **divided** by the oversampling method (by 8 or by 16) and then converted to decimal.

#### Example:

If DIV\_Mantissa = 0d27 and DIV\_Fraction = 0d12 (USART\_BRR = 0x1BC), then Mantissa (USARTDIV) = 0d27
Fraction (USARTDIV) = 12/16 = 0d0.75
Therefore USARTDIV = 0d27.75

To be noted, when converting a decimal USARTDIV value to DIV\_Mantissa and DIV\_Fraction, the mantissa is simply converted to binary and stored in DIV\_Mantissa, while the fraction is **multiplied** by the oversampling method (by 8 or by 16), rounded to nearest whole number and then converted to binary and stored in DIV Fraction.

#### **Example:**

To program USARTDIV = 0d50.99

This leads to:

 $DIV_Fraction = 16*0d0.99 = 0d15.84$ 

The nearest real number is  $0d16 = 0x10 \Rightarrow 0$ 

DIV\_Mantissa = mantissa (0d50 + carry) = 0d51 = 0x33

Then, USART\_BRR = 0x330 hence USARTDIV = 0d51.000

OVER8 is the oversampling mode and is set in USART\_CR1. It is 0 when oversampling by 16, and 1 when oversampling by 8. It should be noted however that

- When OVER8 = 0, the fractional part is coded on 4 bits and programmed by the DIV\_fraction[3:0] bits in the USART\_BRR register
- When OVER8 = 1, the fractional part is coded on 3 bits and programmed by the DIV\_fraction[2:0] bits in the USART\_BRR register, and bit DIV\_fraction[3] must be kept cleared.

## **UART Framing**



9-bit word length (M bit is reset), 1 stop bit



8-bit word length (M bit is reset), 1 stop bit

An UART transmitter sends out these words of data one at a time, and the receiver realizes that it has received a frame when the channel goes from logical high to logical low (since the start bit is generally a logical low, while the line is at a logical high at idle).

There are two ways for determining that an entire frame has been sent or received

- By waiting for the stop bit to be read and checking each bit if it is the stop bit
- By generating an interrupt when the whole frame has been sent or received and determining completion using it.

Since the stop bit is essential to determining the entire frame, it can be configured and both devices have to agree on the size of the stop bit.

Similarly, the size of the data frame can be configured as well, and both devices need to agree on this configuration.

### **UART in STM32**

STM32 has a total of 6-USART peripherals.

- USART 1,2,3 and 6 are full USART, while 4 and 5 can only be used for UART.
- It uses NRZ standard digital signaling.
- USART 1 and 6 Maximum Baud Rate: 11.25 Mbits/s
- USART 2, 3, 4, 5 Maximum Baud Rate: 5.62 Mbits/s

## Necessary Registers (along with descriptions of used bits)

## Control register 1 (USART\_CR1)

| 31          | 30         | 29       | 28      | 27         | 26        | 25      | 24        | 23         | 22        | 21          | 20   | 19      | 18      | 17       | 16       |
|-------------|------------|----------|---------|------------|-----------|---------|-----------|------------|-----------|-------------|------|---------|---------|----------|----------|
| Res.        | Res.       | Res.     | Res.    | Res.       | Res.      | Res.    | Res.      | Res.       | Res.      | Res.        | Res. | Res.    | Res.    | Res.     | Res.     |
|             |            |          |         |            |           |         |           |            |           |             |      |         |         |          |          |
|             |            |          |         |            |           |         |           |            |           |             |      |         |         |          |          |
| 15          | 14         | 13       | 12      | 11         | 10        | 9       | 8         | 7          | 6         | 5           | 4    | 3       | 2       | 1        | 0        |
| 15<br>OVER8 | 14<br>Res. | 13<br>UE | 12<br>M | 11<br>WAKE | 10<br>PCE | 9<br>PS | 8<br>PEIE | 7<br>TXEIE | 6<br>TCIE | 5<br>RXNEIE | · ·  | 3<br>TE | 2<br>RE | 1<br>RWU | 0<br>SBK |

### Baud rate register (USART\_BRR)

| 31   | 30   | 29   | 28   | 27   | 26       | 25         | 24   | 23   | 22   | 21   | 20   | 19   | 18      | 17         | 16   |
|------|------|------|------|------|----------|------------|------|------|------|------|------|------|---------|------------|------|
| Res. | Res. | Res. | Res. | Res. | Res.     | Res.       | Res. | Res. | Res. | Res. | Res. | Res. | Res.    | Res.       | Res. |
|      |      |      |      |      |          |            |      |      |      |      |      |      |         |            |      |
| 15   | 14   | 13   | 12   | 11   | 10       | 9          | 8    | 7    | 6    | 5    | 4    | 3    | 2       | 1          | 0    |
|      |      |      |      | ı    | DIV_Mant | tissa[11:0 | ]    |      |      |      |      |      | DIV_Fra | ction[3:0] |      |
| rw   | rw   | rw   | rw   | rw   | rw       | rw         | rw   | rw   | rw   | rw   | rw   | rw   | rw      | rw         | rw   |

#### Status register (USART\_SR)

| 31         | 30         | 29         | 28         | 27         | 26         | 25       | 24       | 23       | 22      | 21        | 20        | 19       | 18      | 17      | 16      |
|------------|------------|------------|------------|------------|------------|----------|----------|----------|---------|-----------|-----------|----------|---------|---------|---------|
| Res.       | Res.       | Res.       | Res.       | Res.       | Res.       | Res.     | Res.     | Res.     | Res.    | Res.      | Res.      | Res.     | Res.    | Res.    | Res.    |
|            |            |            |            |            |            |          |          |          |         |           |           |          |         |         |         |
|            |            |            |            |            |            |          |          |          |         |           |           |          |         |         |         |
| 15         | 14         | 13         | 12         | 11         | 10         | 9        | 8        | 7        | 6       | 5         | 4         | 3        | 2       | 1       | 0       |
| 15<br>Res. | 14<br>Res. | 13<br>Res. | 12<br>Res. | 11<br>Res. | 10<br>Res. | 9<br>CTS | 8<br>LBD | 7<br>TXE | 6<br>TC | 5<br>RXNE | 4<br>IDLE | 3<br>ORE | 2<br>NF | 1<br>FE | 0<br>PE |

### Data register (USART\_DR)

| 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20      | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|------|------|------|------|------|---------|------|------|------|------|
| Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res.    | Res. | Res. | Res. | Res. |
|      |      |      |      |      |      |      |      |      |      |      |         |      |      |      |      |
| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4       | 3    | 2    | 1    | 0    |
| Res. | Res. | Res. | Res. | Res. | Res. | Res. |      |      |      |      | DR[8:0] |      |      |      |      |
|      |      |      |      |      |      |      | rw   | rw   | rw   | rw   | rw      | rw   | rw   | rw   | rw   |

#### Procedure

- 1. Enable the clock for the USART peripheral (from the RCC\_APBxENR, USARTxEN) and the clock for the GPIO pins for that peripheral (consult reference manual table 10) (from RCC\_AHBxENR, GPIOxEN)
- Configure the pins for alternate functions (in GPIOx\_MODER, set the particular pins to 10 for alternate function mode), then set them to high speed (in GPIOx\_OSPEEDR), and lastly select their alternate function to be that of USART (in GPIOx\_AFR)
- 3. Then enable the USART by writing the **UE bit in USARTx\_CR1** register to 1
- 4. Program the M bit in USARTx\_CR1 to define the word length
- 5. Configure the desired baud rate **using the USARTx\_BRR** register (common baud rates include 9600, 115200)
- 6. Enable the Transmitter/Receiver by Setting the **TE and RE bits in USARTx\_CR1**Register
- Enable interrupt for simpler completion of transmission/receiver (in USARTx\_CR1, RXNEIE)
- 8. Transmit data in the following manner
  - a. Write the data to send in the **USARTx\_DR** register (this clears the **TXE bit in USARTx\_SR**).
  - After writing the last data into the USARTx\_DR register, wait until TC=1 (in USARTx\_SR). This indicates that the transmission of the last frame is complete.
- 9. Receive data in the following manner

- a. Wait for the **RXNE bit (in USARTx\_SR)** to set. It indicates that the data has been received and can be read.
- b. Read the data from **USARTx\_DR** Register. This also clears the **RXNE bit (in USARTx\_SR)**

## 12C

Inter Integrated Circuit (IIC or  $I^2C$ ) is a half-duplex, serial, synchronous communication protocol. It is a two wire protocol, with the data line and the clock line to synchronize the clock.

Masters are the devices that generate clock signal and initiates communication, and slave are those devices that receives the clock and responds when addressed by master. It is multi-master and multi-slave bus.

It uses two bi-directional open collector or open drain lines:

SDA : Serial Data LineSCL : Serial Clock Line

## Advantages

- Supports multi-master and multi-slave
- Due to device addressing, no chip select pin (SPI) required. Hence, reduced number of pins
- Better error handling is available with ACK bit
- Due to clock stretching, it can work well with both slow and fast ICs

#### Transmission Mode

- Slave transmitter
- Slave receiver
- Master transmitter
- Master receiver

#### Slave Mode

By default the I2C interface operates in Slave mode. As soon as a start condition is detected, the address is received from the SDA line and sent to the shift register. Then it is compared with the address of the interface.

**Header or address not matched:** the interface ignores it and waits for another Start condition.

**Header matched (10-bit mode only):** the interface generates an acknowledge pulse if the ACK bit is set and waits for the 8-bit slave address.

**Address matched:** the interface generates in sequence:

• An acknowledge pulse if the ACK bit is set

- The ADDR bit is set by hardware and an interrupt is generated if the ITEVFEN bit is set.
- If ENDUAL=1, the software has to read the DUALF bit to check which slave address has been acknowledged.

In 10-bit mode, after receiving the address sequence the slave is always in Receiver mode.

It will enter Transmitter mode on receiving a repeated Start condition followed by the header sequence with matching address bits and the least significant bit set (11110xx1).

The TRA bit indicates whether the slave is in Receiver or Transmitter mode.

To switch from default Slave mode to Master mode a Start condition generation is needed.

#### Master Mode

In Master mode, the I2C interface initiates a data transfer and generates the clock signal. A serial data transfer always begins with a Start condition and ends with a Stop condition. Master mode is selected as soon as the Start condition is generated on the bus with a START bit.

The following is the required sequence in master mode.

- Program the peripheral input clock in I2C\_CR2 Register in order to generate correct timings
- Configure the clock control registers
- Configure the rise time register
- Program the I2C\_CR1 register to enable the peripheral
- Set the START bit in the I2C\_CR1 register to generate a Start condition

#### Slave address transmission

Then the slave address is sent to the SDA line via the internal shift register.

- In 10-bit addressing mode, sending the header sequence causes the following event:
  - The ADD10 bit is set by hardware and an interrupt is generated if the ITEVFEN bit is set.

Then the master waits for a read of the SR1 register followed by a write in the DR register with the second address byte

• The ADDR bit is set by hardware and an interrupt is generated if the ITEVFEN bit is set.

Then the master waits for a read of the SR1 register followed by a read of the SR2 register

• In 7-bit addressing mode, one address byte is sent. As soon as the address byte is sent,

 The ADDR bit is set by hardware and an interrupt is generated if the ITEVFEN bit is set.

Then the master waits for a read of the SR1 register followed by a read of the SR2 register

## 12C Transfer Sequence

First, a start bit or start condition is generated by a master, and sends its clock. There is bus arbitration on this line, and only one master can use the bus at a time.

Along the I2C bus, each node (master and slave) has a address (7 or 10 bits), and the transmitter sends the address on the bus along with a bit for read or write and waits for an acknowledgement. Once an acknowledgement is received, i.e. the addressed device exists on the bus, data is sent and acknowledgement is waited for.

When the master transmits, the following transfer sequence is sent (is the slave received frame)



Legend: S = Start, SR = Repeated start, P = stop, A = Acknowledge

EVx = Event (with interrupt if ITEVFEN = 1)

EV5: SB=1, cleared by reading SR1 register followed by writing DR register with address.

EV6: ADDR=1, cleared by reading SR1 register followed by reading SR2.

EV8 1: TxE=1, shift register empty, data register empty, write Data1 in DR.

EV8: TxE=1, shift register not empty, data register empty, cleared by writing DR register.

EV 2: TxE=1, BTF=1, Program stop request, TxE and BTF are cleared by hardware by the stop condition.

EV9: ADD10=1, cleared by reading SR1 register followed by writing DR register.

When the master receives, the following transfer sequence is received (is the slave transmitted frame)



Legend: S= Start, S<sub>r</sub> = Repeated Start, P= Stop, A= Acknowledge, NA= Non-acknowledge,

EVx= Event (with interrupt if ITEVFEN=1)

EV5: SB=1, cleared by reading SR1 register followed by writing DR register.

EV6: ADDR=1, cleared by reading SR1 register followed by reading SR2. In 10-bit master receiver mode, this sequence should be followed by writing CR2 with START = 1.

In case of the reception of 1 byte, the Acknowledge disable must be performed during EV6 event, i.e. before clearing ADDR flag. EV7: RxNE=1 cleared by reading DR register.

EV7\_1: RxNE=1 cleared by reading DR register, program ACK=0 and STOP request

EV9: ADD10=1, cleared by reading SR1 register followed by writing DR register.

### Necessary Registers (along with descriptions of used bits)

## I2C Control Register 1 (I2C\_CR1)

| 15        | 14   | 13    | 12  | 11  | 10  | 9    | 8     | 7                 | 6    | 5     | 4     | 3           | 2    | 1         | 0  |   |
|-----------|------|-------|-----|-----|-----|------|-------|-------------------|------|-------|-------|-------------|------|-----------|----|---|
| SW<br>RST | Res. | ALERT | PEC | POS | ACK | STOP | START | NO<br>STRET<br>CH | ENGC | ENPEC | ENARP | SMB<br>TYPE | Res. | SM<br>BUS | PE |   |
| rw        |      | rw    | rw  | rw  | rw  | rw   | rw    | rw                | rw   | rw    | rw    | rw          |      | rw        | rw | I |

## I2C Control Register 2 (I2C\_CR2)

| 15   | 14   | 13   | 12   | 11        | 10          | 9           | 8           | 7    | 6    | 5         | 4  | 3  | 2  | 1  | 0  |
|------|------|------|------|-----------|-------------|-------------|-------------|------|------|-----------|----|----|----|----|----|
| Res. | Res. | Res. | LAST | DMA<br>EN | ITBUF<br>EN | ITEVT<br>EN | ITERR<br>EN | Res. | Res. | FREQ[5:0] |    |    |    |    |    |
|      |      |      | rw   | rw        | rw          | rw          | rw          |      |      | rw        | rw | rw | rw | rw | rw |

## I2C Clock control register (I2C\_CCR)

| 15  | 14   | 13   | 12   | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|------|------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|
| F/S | DUTY | Res. | Res. | CCR[11:0] |    |    |    |    |    |    |    |    |    |    |    |
| rw  | rw   |      |      | rw        | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

## I2C TRISE register (I2C\_TRISE)

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5  | 4          | 3  | 2  | 1  | 0  |  |
|------|------|------|------|------|------|------|------|------|------|----|------------|----|----|----|----|--|
| Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. | Res. |    | TRISE[5:0] |    |    |    |    |  |
|      |      |      |      |      |      |      |      |      |      | rw | rw         | rw | rw | rw | rw |  |

## I2C Status register 1 (I2C\_SR1)

| 15           | 14          | 13   | 12         | 11    | 10    | 9     | 8     | 7   | 6    | 5    | 4     | 3     | 2   | 1    | 0  |
|--------------|-------------|------|------------|-------|-------|-------|-------|-----|------|------|-------|-------|-----|------|----|
| SMB<br>ALERT | TIMEO<br>UT | Res. | PEC<br>ERR | OVR   | AF    | ARLO  | BERR  | TxE | RxNE | Res. | STOPF | ADD10 | BTF | ADDR | SB |
| rc_w0        | rc_w0       |      | rc_w0      | rc_w0 | rc_w0 | rc_w0 | rc_w0 | r   | r    |      | r     | r     | r   | r    | r  |

### I2C Status register 2 (I2C\_SR2)

Note: Reading I2C\_SR2 after reading I2C\_SR1 clears the ADDR flag, even if the ADDR flag was set after reading I2C\_SR1. Consequently, I2C\_SR2 must be read only when ADDR is found set in I2C\_SR1 or when the STOPF bit is cleared.

| 1 | 5        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6           | 5                  | 4           | 3    | 2   | 1    | 0   |
|---|----------|----|----|----|----|----|---|---|-------|-------------|--------------------|-------------|------|-----|------|-----|
|   | PEC[7:0] |    |    |    |    |    |   |   | DUALF | SMB<br>HOST | SMB<br>DEFAU<br>LT | GEN<br>CALL | Res. | TRA | BUSY | MSL |
| r | r        | r  | r  | r  | r  | r  | r | r | r     | r           | r                  | r           |      | r   | r    | r   |

### Procedure

## Configuration

- 1. Enable the I2C clock and GPIO clock (for the I2C pins) (using RCC\_APB1ENR and RCC\_AHB1ENR)
- 2. Configure the I2C GPIO pins for alternate functions (using GPIOx\_MODER), setting the output type to open drain (using GPIOx\_OTYPER), and speed to high (using GPIOx\_OSPEEDR), and to pull-up (using GPIOx\_PUPDR) and picking I2C as the alternate function (using GPIOx\_AFR)
- 3. Reset the I2C (using I2C\_CR1, the SW RST)
- 4. Program the peripheral input clock in order to generate correct timings (using I2C\_CR2, FREQ) [should be the same as PCLK1]
- 5. Configure the clock control registers (using I2C CCR) [example value is 225]
- 6. Configure the rise time register (using I2C TRISE) [example value is 46]
- 7. Program the I2C\_CR1 register (the PE bit) to enable the peripheral

### Start/Initiating Communication by the Master

- 1. Enable the ACK bit so acknowledgement is sent (using I2C\_CR1, ACK)
- 2. Send the START condition by generating START (using I2C\_CR1, START)
- 3. Wait for the SB (in I2C\_SR1) to set. This indicates that the start condition is generated

#### Sending Slave Address

- 1. Send the Slave Address to the I2C\_DR Register
- 2. Wait for the ADDR (in I2C\_SR1) to set. This indicates the end of address transmission
- 3. Clear the ADDR by reading the SR1 and SR2

#### Write

- 1. Wait for the TXE (in I2C\_SR1) to set. This indicates that the DR is empty
- 2. Send the DATA to the I2C DR Register
- 3. Wait for the BTF (in I2C\_SR1) to set. This indicates the end of LAST DATA transmission

#### Read

- 1. If only 1 BYTE needs to be Read
  - a. Write the slave Address, and wait for the ADDR bit (bit 1 in SR1) to be set
  - b. the Acknowledge disable is made during EV6 (before ADDR flag is cleared) and the STOP condition generation is made after EV6
  - c. Wait for the RXNE (Receive Buffer not Empty) bit to set
  - d. Read the data from the DR
- 2. If Multiple BYTES needs to be read
  - a. Write the slave Address, and wait for the ADDR bit (bit 1 in SR1) to be set
  - b. Clear the ADDR bit by reading the SR1 and SR2 Registers
  - c. Wait for the RXNE (Receive buffer not empty) bit to set
  - d. Read the data from the DR
  - e. Generate the acknowledgment by setting the ACK (bit 10 in SR1)
  - f. To generate the non acknowledge pulse after the last received data byte, the ACK bit must be cleared just after reading the second last data byte (after second last RxNE event)
  - g. In order to generate the Stop/Restart condition, software must set the STOP/START bit after reading the second last data byte (after the second last RxNE event)

### Stop

1. Stop I2C (using I2C\_CR1, STOP)

# Viva Questions

- 1. Pin koita kon port e
- 2. Interrupt ki, polling method ki, difference ki
- 3. Synchronization (kibhabe, kothae ase kothae nai, keno lage)
- 4. Show signal diagrams (clock counter trail)