

## ARM®-based 32-bit Cortex®-M4F MCU+FPU, with 128 to 256 KB Flash, sLib, USBFS/HS-OTG, 12 timers, 1 ADC, 20 communication interfaces

### ■ Core: ARM® 32-bit Cortex®-M4F CPU with FPU

- 216 MHz maximum frequency, with a Memory Protection Unit (MPU), single-cycle multiplication and hardware division
- Floating Point Unit (FPU)
- DSP instructions

### ■ Memories

- 128 to 256 Kbytes of Flash memory
- 20 Kbytes of boot memory used as a Bootloader or as a general instruction/data memory (one-time configured)
- sLib: configurable part of main Flash as a library area with code executable but secured, non-readable
- 70 to 102 Kbytes of SRAM (the first 48 KB with parity check option)
- 1x QSPI interface to connect with external SPI Flash or SPI RAM extension, supporting address mapping mode

### ■ Power control (PWC)

- 2.4 V to 3.6 V power supply
- Power-on reset (POR)/low voltage reset (LVR), and power voltage monitor (PVM)
- Low-power modes: Sleep, Deepsleep and Standby modes
- 20 x 32-bit RTC data registers (BPR)

### ■ Clock and reset management (CRM)

- 4 to 25 MHz crystal (HEXT)
- 48 MHz internal factory-trimmed HICK ( $\pm 1\%$  at  $TA=25\text{ }^{\circ}\text{C}$ ,  $\pm 2\%$  at  $TA=-40\text{ }^{\circ}\text{C}$  to  $+105\text{ }^{\circ}\text{C}$ ), with automatic clock calibration (ACC)
- PLL with configurable frequency multiplication and division factors
- 32.768 kHz crystal (LEXT)
- Low speed internal clock (LICK)

### ■ Analog

- 1 x 12-bit 2 MSPS A/D converter, up to 16 external input channels, hardware over-sampling up to equivalent 16-bit resolution
- Temperature sensor ( $V_{TS}$ ), internal reference voltage ( $V_{INTR}$ )

### ■ DMA

- 2 x 7-channel DMA controllers

### ■ Up to 56 fast GPIOs

- All mappable on 16 external interrupts
- Almost 5 V-tolerant

### ■ Up to 14 timers (TMR)

- 1 x 16-bit 4-channel advanced timer, each channel PWM output with dead-time generator and emergency brake
- Up to 1 x 32-bit and 7 x 16-bit general-purpose timers, each with 4 IC/OC/PWM or pulse counter

and incremental encoder input; including 5 timers supporting complementary output with dead-time generator and emergency brake

- 2 x 16-bit basic timers
- 2 x watchdog timers (WDT and WWDT)
- SysTick timer: 24-bit downcounter

### ■ ERTC: enhanced RTC, with auto wakeup, alarm, subsecond accuracy, hardware calendar, and calibration feature

### ■ Up to 19 communication interfaces

- Up to 3 x I<sup>2</sup>C interfaces (SMBus/PMBus)
- Up to 8 x USARTs/UARTs (ISO7816 interface, LIN, IrDA capability, modem control and RS485 drive enable, TX/RX swap)
- 3 x SPIs, all with I<sup>2</sup>S interface multiplexed, any combination of two interfaces support full-duplex, with 1 full-duplex I<sup>2</sup>SF interface
- 1 x CAN interface (2.0B Active)
- USB2.0 FS/host/OTG device interface, supporting crystal-less in device mode
- USB2.0 HS/host/OTG device interface, supporting crystal-less in device mode
- 1 x QSPI
- Infrared transmitter (IRTMR)

### ■ CRC calculation unit

### ■ 96-bit unique ID (UID)

### ■ Debug mode

- SWD interface

### ■ Operating temperature: -40 to +105 °C

### ■ Packages

- LQFP64 10 x 10 mm
- LQFP64 7 x 7 mm
- LQFP48 7 x 7 mm
- QFN48 6 x 6 mm
- QFN32 4 x 4 mm

### ■ List of models

| Internal Flash | Model                                                                                                                                                    |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 128 Kbytes     | AT32F405RBT7 AT32F405RBT7-7<br>AT32F405CBT7 AT32F405CBU7<br>AT32F405KBU7-4<br>AT32F402RBT7 AT32F402RBT7-7<br>AT32F402CBT7 AT32F402CBU7<br>AT32F402KBU7-4 |
| 256 Kbytes     | AT32F405RCT7 AT32F405RCT7-7<br>AT32F405CCT7 AT32F405CCU7<br>AT32F405KCU7-4<br>AT32F402RCT7 AT32F402RCT7-7<br>AT32F402CCT7 AT32F402CCU7<br>AT32F402KCU7-4 |

## Contents

|          |                                                      |           |
|----------|------------------------------------------------------|-----------|
| <b>1</b> | <b>System architecture .....</b>                     | <b>33</b> |
| 1.1      | System overview .....                                | 34        |
| 1.1.1    | ARM Cortex®-M4F processor .....                      | 34        |
| 1.1.2    | Bit band .....                                       | 34        |
| 1.1.3    | Interrupt and exception vectors .....                | 36        |
| 1.1.4    | System Tick (SysTick) .....                          | 40        |
| 1.1.5    | Reset .....                                          | 40        |
| 1.2      | List of abbreviations for registers .....            | 41        |
| 1.3      | Device characteristics information .....             | 42        |
| 1.3.1    | Flash memory size register .....                     | 42        |
| 1.3.2    | Device electronic signature .....                    | 42        |
| <b>2</b> | <b>Memory resources .....</b>                        | <b>43</b> |
| 2.1      | Internal memory address map .....                    | 43        |
| 2.2      | Flash memory .....                                   | 44        |
| 2.3      | SRAM memory .....                                    | 45        |
| 2.4      | Peripheral address map .....                         | 45        |
| <b>3</b> | <b>Power control (PWC).....</b>                      | <b>48</b> |
| 3.1      | Introduction .....                                   | 48        |
| 3.2      | Main features .....                                  | 48        |
| 3.3      | POR/LVR .....                                        | 49        |
| 3.4      | Power voltage monitor (PVM).....                     | 49        |
| 3.5      | Power domain .....                                   | 50        |
| 3.6      | Power saving modes .....                             | 50        |
| 3.7      | PWC registers .....                                  | 52        |
| 3.7.1    | Power control register (PWC_CTRL) .....              | 52        |
| 3.7.2    | Power control/status register (PWC_CTRLSTS) .....    | 53        |
| 3.7.3    | LDO output voltage select register (PWC_LDOOV) ..... | 54        |
| <b>4</b> | <b>Clock and reset manage (CRM).....</b>             | <b>55</b> |
| 4.1      | Clock .....                                          | 55        |

|                                                                                        |    |
|----------------------------------------------------------------------------------------|----|
| 4.1.1 Clock sources .....                                                              | 56 |
| 4.1.2 System clock.....                                                                | 57 |
| 4.1.3 Peripheral clock .....                                                           | 57 |
| 4.1.4 Clock fail detector .....                                                        | 57 |
| 4.1.5 Auto step-by-step system clock switch.....                                       | 58 |
| 4.1.6 Internal clock output.....                                                       | 58 |
| 4.1.7 Interrupts.....                                                                  | 58 |
| 4.2 Reset.....                                                                         | 58 |
| 4.2.1 System reset.....                                                                | 58 |
| 4.2.2 Battery powered domain reset.....                                                | 59 |
| 4.3 CRM registers .....                                                                | 59 |
| 4.3.1 Clock control register (CRM_CTRL).....                                           | 59 |
| 4.3.2 PLL clock configuration register (CRM_PLLCFG) .....                              | 61 |
| 4.3.3 Clock configuration register (CRM_CFG) .....                                     | 62 |
| 4.3.4 Clock interrupt register (CRM_CLKINT) .....                                      | 63 |
| 4.3.5 AHB peripheral reset register 1 (CRM_AHBRST1) .....                              | 64 |
| 4.3.6 AHB peripheral reset register 2 (CRM_AHBRST2) .....                              | 65 |
| 4.3.7 AHB peripheral reset register 3 (CRM_AHBRST3) .....                              | 65 |
| 4.3.8 APB1 peripheral reset register (CRM_APB1RST) .....                               | 65 |
| 4.3.9 APB2 peripheral reset register (CRM_APB2RST) .....                               | 67 |
| 4.3.10 AHB peripheral clock enable register 1 (CRM_AHBEN1).....                        | 67 |
| 4.3.11 AHB peripheral clock enable register 2 (CRM_AHBEN2).....                        | 68 |
| 4.3.12 AHB peripheral clock enable register 3 (CRM_AHBEN3).....                        | 68 |
| 4.3.13 APB1 peripheral clock enable register (CRM_APB1EN) .....                        | 68 |
| 4.3.14 APB2 peripheral clock enable register (CRM_APB2EN) .....                        | 69 |
| 4.3.15 AHB peripheral clock enable in low-power mode register 1<br>(CRM_AHBLPEN1)..... | 70 |
| 4.3.16 AHB peripheral clock enable in low-power mode register 2<br>(CRM_AHBLPEN2)..... | 71 |
| 4.3.17 AHB peripheral clock enable in low-power mode register 3<br>(CRM_AHBLPEN3)..... | 71 |
| 4.3.18 APB1 peripheral clock enable in low-power mode register<br>(CRM_APB1LPEN) ..... | 71 |
| 4.3.19 APB2 peripheral clock enable in low-power mode register<br>(CRM_APB2LPEN) ..... | 72 |
| 4.3.20 Battery powered domain control register (CRM_BPDC).....                         | 73 |

|                                                                        |           |
|------------------------------------------------------------------------|-----------|
| 4.3.21 Control/status register (CRM_CTRLSTS) .....                     | 74        |
| 4.3.22 OTGHS control register (CRM_OTGHS).....                         | 74        |
| 4.3.23 Additional register 1 (CRM_MISC1) .....                         | 75        |
| 4.3.24 Additional register 2 (CRM_MISC2) .....                         | 75        |
| <b>5     Flash memory controller (FLASH).....</b>                      | <b>77</b> |
| 5.1    FLASH introduction .....                                        | 77        |
| 5.2    Flash memory operation .....                                    | 79        |
| 5.2.1    Unlock/lock .....                                             | 79        |
| 5.2.2    Erase operation.....                                          | 79        |
| 5.2.3    Programming operation.....                                    | 81        |
| 5.2.4    Read operation .....                                          | 82        |
| 5.3    Main Flash memory extension area .....                          | 83        |
| 5.4    User system data area operation.....                            | 83        |
| 5.4.1    Unlock/lock .....                                             | 83        |
| 5.4.2    Erase operation.....                                          | 83        |
| 5.4.3    Programming operation.....                                    | 84        |
| 5.4.4    Read operation .....                                          | 85        |
| 5.5    Flash memory protection .....                                   | 85        |
| 5.5.1    Access protection.....                                        | 85        |
| 5.5.2    Erase/program protection.....                                 | 86        |
| 5.6    Read access.....                                                | 87        |
| 5.7    Special functions .....                                         | 87        |
| 5.7.1    Security library settings .....                               | 87        |
| 5.7.2    Boot memory used as Flash memory extension .....              | 88        |
| 5.7.3    CRC verify .....                                              | 88        |
| 5.8    FLASH registers .....                                           | 88        |
| 5.8.1    Flash performance select register (FLASH_PSR) .....           | 89        |
| 5.8.2    Flash unlock register (FLASH_UNLOCK) .....                    | 89        |
| 5.8.3    Flash user system data unlock register (FLASH_USD_UNLOCK) ... | 90        |
| 5.8.4    Flash status register (FLASH_STS) .....                       | 90        |
| 5.8.5    Flash control register (FLASH_CTRL).....                      | 90        |
| 5.8.6    Flash address register (FLASH_ADDR) .....                     | 91        |
| 5.8.7    User system data register (FLASH_USD).....                    | 91        |
| 5.8.8    Erase/program protection status register (FLASH_EPPS) .....   | 91        |

|                                                                                       |           |
|---------------------------------------------------------------------------------------|-----------|
| 5.8.9 Flash security library status register 0 (SLIB_STS0).....                       | 91        |
| 5.8.10 Flash security library status register 1 (SLIB_STS1).....                      | 92        |
| 5.8.11 Security library password clear register (SLIB_PWD_CLR) .....                  | 92        |
| 5.8.12 Security library additional status register (SLIB_MISC_STS).....               | 93        |
| 5.8.13 Flash CRC address register (FLASH_CRC_ADDR) .....                              | 93        |
| 5.8.14 Flash CRC check control register (FLASH_CRC_CTRL) .....                        | 93        |
| 5.8.15 Flash CRC check result register (FLASH_CRC_CHK).....                           | 93        |
| 5.8.16 Security library password setting register (SLIB_SET_PWD).....                 | 94        |
| 5.8.17 Security library address setting register (SLIB_SET_RANGE) .....               | 94        |
| 5.8.18 Flash extension memory security library setting register<br>(EM_SLIB_SET)..... | 95        |
| 5.8.19 Boot memory mode setting register (BTM_MODE_SET) .....                         | 95        |
| 5.8.20 Security library unlock register (SLIB_UNLOCK) .....                           | 95        |
| <b>6      GPIOs and IOMUX .....</b>                                                   | <b>96</b> |
| 6.1    Introduction .....                                                             | 96        |
| 6.2    Function overview .....                                                        | 96        |
| 6.2.1    GPIO structure .....                                                         | 96        |
| 6.2.2    GPIO reset status.....                                                       | 97        |
| 6.2.3    General-purpose input configuration.....                                     | 97        |
| 6.2.4    Analog mode configuration.....                                               | 97        |
| 6.2.5    General-purpose output configuration .....                                   | 97        |
| 6.2.6    I/O port write protection .....                                              | 98        |
| 6.2.7    IOMUX structure .....                                                        | 98        |
| 6.2.8    Multiplexed function configuration .....                                     | 99        |
| 6.2.9    IOMUX input/output .....                                                     | 100       |
| 6.2.10 Peripheral MUX function configuration .....                                    | 107       |
| 6.2.11 IOMUX mapping priority .....                                                   | 107       |
| 6.2.12 External interrupt/wake-up lines .....                                         | 107       |
| 6.3    GPIO registers.....                                                            | 108       |
| 6.3.1    GPIO configuration register (GPIOx_CFGR) (x=A..F).....                       | 108       |
| 6.3.2    GPIO output mode register (GPIOx_OMODE) (x=A..F).....                        | 108       |
| 6.3.3    GPIO drive capability register (GPIOx_ODRVR) (x=A..F) .....                  | 109       |
| 6.3.4    GPIO pull-up/pull-down register (GPIOx_PULL) (x=A..F) .....                  | 109       |
| 6.3.5    GPIO input data register (GPIOx_IDT) (x=A..F) .....                          | 109       |

|          |                                                                  |            |
|----------|------------------------------------------------------------------|------------|
| 6.3.6    | GPIO output data register (GPIOx_ODT) (x=A..F) .....             | 109        |
| 6.3.7    | GPIO set/clear register (GPIOx_SCR) (x=A..F) .....               | 109        |
| 6.3.8    | GPIO write protection register (GPIOx_WPR) (x=A..F).....         | 110        |
| 6.3.9    | GPIO multiplexed function low register (GPIOx_MUXL) (x=A..F) ... | 110        |
| 6.3.10   | GPIO multiplexed function high register (GPIOx_MUXH) (x=A..F)..  | 111        |
| 6.3.11   | GPIO port bit clear register (GPIOx_CLR) (x=A..F).....           | 111        |
| 6.3.12   | GPIO port bit toggle register (GPIOx_TOGR) (x=A..F) .....        | 112        |
| 6.3.13   | GPIO huge current control register (GPIOx_HDRV) (x=A..F) .....   | 112        |
| <b>7</b> | <b>System configuration controller (SYSCFG).....</b>             | <b>113</b> |
| 7.1      | Introduction .....                                               | 113        |
| 7.2      | SCFG registers.....                                              | 113        |
| 7.2.1    | SCFG configuration register 1 (SCFG_CFG1) .....                  | 113        |
| 7.2.2    | SCFG configuration register 2 (SCFG_CFG2) .....                  | 113        |
| 7.2.3    | SCFG external interrupt configuration register 1 (SCFG_EXINTC1)  | 114        |
| 7.2.4    | SCFG external interrupt configuration register 2 (SCFG_EXINTC2)  | 115        |
| 7.2.5    | SCFG external interrupt configuration register 3 (SCFG_EXINTC3)  | 115        |
| 7.2.6    | SCFG external interrupt configuration register 4 (SCFG_EXINTC4)  | 116        |
| 7.2.7    | SCFG ultra high sourcing/sinking strength register (SCFG_UHDRV)  | 117        |
| <b>8</b> | <b>External interrupt/event controller (EXINT).....</b>          | <b>118</b> |
| 8.1      | EXINT introduction.....                                          | 118        |
| 8.2      | Function overview and configuration procedure .....              | 118        |
| 8.3      | EXINT registers .....                                            | 119        |
| 8.3.1    | Interrupt enable register (EXINT_INTEN).....                     | 119        |
| 8.3.2    | Event enable register (EXINT_EVTEN).....                         | 119        |
| 8.3.3    | Polarity configuration register 1 (EXINT_POLCFG1).....           | 119        |
| 8.3.4    | Polarity configuration register 2 (EXINT_POLCFG2).....           | 119        |
| 8.3.5    | Software trigger register (EXINT_SWTRG).....                     | 120        |
| 8.3.6    | Interrupt status register (EXINT_INTSTS) .....                   | 120        |
| <b>9</b> | <b>DMA controller (DMA) .....</b>                                | <b>121</b> |
| 9.1      | Introduction .....                                               | 121        |
| 9.2      | Main features .....                                              | 121        |
| 9.3      | Function overview .....                                          | 122        |

|                                                                                  |            |
|----------------------------------------------------------------------------------|------------|
| 9.3.1 DMA configuration .....                                                    | 122        |
| 9.3.2 Handshake mechanism .....                                                  | 122        |
| 9.3.3 Arbiter .....                                                              | 122        |
| 9.3.4 Programmable data transfer width .....                                     | 123        |
| 9.3.5 Errors .....                                                               | 124        |
| 9.3.6 Interrupts .....                                                           | 124        |
| 9.4 DMA multiplexer (DMAMUX) .....                                               | 124        |
| 9.4.1 DMAMUX function overview .....                                             | 124        |
| 9.4.2 DMAMUX overflow interrupts .....                                           | 126        |
| 9.5 DMA registers .....                                                          | 127        |
| 9.5.1 DMA interrupt status register (DMA_STS) .....                              | 129        |
| 9.5.2 DMA interrupt flag clear register (DMA_CLR) .....                          | 131        |
| 9.5.3 DMA channel-x configuration register (DMA_CxCTRL) (x=1...7) .....          | 133        |
| 9.5.4 DMA channel-x number of data register (DMA_CxDTCNT) (x=1...7) .....        | 134        |
| 9.5.5 DMA channel-x peripheral address register (DMA_CxPADDR)<br>(x=1...7) ..... | 134        |
| 9.5.6 DMA channel-x memory address register (DMA_CxMADDR) (x=1...7) .....        | 134        |
| 9.5.7 DMAMUX select register (DMA_MUXSEL) .....                                  | 134        |
| 9.5.8 DMAMUX channel-x control register (DMA_MUXCxCTRL) (x=1...7) .....          | 135        |
| 9.5.9 DMAMUX generator-x control register (DMA_MUXGxCTRL) (x=1...4) .....        | 136        |
| 9.5.10 DMAMUX channel synchronization status register<br>(DMA_MUXSYNCSTS) .....  | 136        |
| 9.5.11 DMAMUX channel interrupt flag clear register (DMA_MUXSYNCCCLR) .....      | 136        |
| 9.5.12 DMAMUX generator interrupt status register (DMA_MUXGSTS) .....            | 137        |
| 9.5.13 DMAMUX generator interrupt flag clear register (DMA_MUXGCLR) .....        | 137        |
| <b>10 CRC calculation unit (CRC) .....</b>                                       | <b>138</b> |
| 10.1 CRC introduction .....                                                      | 138        |
| 10.2 CRC function description .....                                              | 138        |
| 10.3 CRC registers .....                                                         | 139        |
| 10.3.1 Data register (CRC_DT) .....                                              | 139        |
| 10.3.2 Common data register (CRC_CDT) .....                                      | 139        |
| 10.3.3 Control register (CRC_CTRL) .....                                         | 140        |
| 10.3.4 Initialization register (CRC_IDT) .....                                   | 140        |
| 10.3.5 Polynomial register (CRC_POLY) .....                                      | 140        |

|                                                                                |            |
|--------------------------------------------------------------------------------|------------|
| <b>11 I<sup>2</sup>C interface .....</b>                                       | <b>141</b> |
| 11.1 I <sup>2</sup> C Introduction .....                                       | 141        |
| 11.2 I <sup>2</sup> C main features .....                                      | 141        |
| 11.3 I <sup>2</sup> C function overview .....                                  | 141        |
| 11.4 I <sup>2</sup> C Interface .....                                          | 142        |
| 11.4.1 I <sup>2</sup> C timing control .....                                   | 143        |
| 11.4.2 Data transfer management.....                                           | 145        |
| 11.4.3 I <sup>2</sup> C master communication flow .....                        | 146        |
| 11.4.4 I <sup>2</sup> C slave communication flow .....                         | 151        |
| 11.4.5 SMBus.....                                                              | 154        |
| 11.4.6 SMBus master communication flow.....                                    | 156        |
| 11.4.7 SMBus slave communication flow .....                                    | 160        |
| 11.4.8 Data transfer using DMA.....                                            | 164        |
| 11.4.9 Error management.....                                                   | 165        |
| 11.5 I <sup>2</sup> C interrupt requests .....                                 | 166        |
| 11.6 I <sup>2</sup> C debug mode .....                                         | 166        |
| 11.7 I <sup>2</sup> C registers .....                                          | 166        |
| 11.7.1 Control register 1 (I2C_CTRL1).....                                     | 167        |
| 11.7.2 Control register 2 (I2C_CTRL2).....                                     | 168        |
| 11.7.3 Address register 1 (I2C_OADDR1) .....                                   | 169        |
| 11.7.4 Address register 2 (I2C_OADDR2) .....                                   | 169        |
| 11.7.5 Timing register (I2C_CLKCTRL).....                                      | 169        |
| 11.7.6 Timeout register (I2C_TIMEOUT) .....                                    | 170        |
| 11.7.7 Status register (I2C_STS) .....                                         | 170        |
| 11.7.8 Status clear flag (I2C_CLR) .....                                       | 172        |
| 11.7.9 PEC register (I2C_PEC) .....                                            | 172        |
| 11.7.10 Receive data register (I2C_RXDT).....                                  | 172        |
| 11.7.11 Transmit data register (I2C_TXDT) .....                                | 172        |
| <b>12 Universal synchronous/asynchronous receiver/transmitter (USART).....</b> | <b>173</b> |
| 12.1 USART introduction .....                                                  | 173        |
| 12.2 Full-duplex/half-duplex selector .....                                    | 175        |
| 12.3 Mode selector.....                                                        | 175        |
| 12.3.1 Introduction.....                                                       | 175        |

|                                                               |            |
|---------------------------------------------------------------|------------|
| 12.3.2 Configuration procedure .....                          | 175        |
| 12.4 USART frame format and configuration.....                | 178        |
| 12.5 DMA transfer introduction .....                          | 180        |
| 12.5.1 Transmission using DMA .....                           | 180        |
| 12.5.2 Reception using DMA .....                              | 181        |
| 12.6 Baud rate generation.....                                | 181        |
| 12.6.1 Introduction.....                                      | 181        |
| 12.6.2 Configuration .....                                    | 181        |
| 12.7 Transmitter.....                                         | 182        |
| 12.7.1 Introduction.....                                      | 182        |
| 12.7.2 Transmitter configuration .....                        | 182        |
| 12.8 Receiver .....                                           | 183        |
| 12.8.1 Introduction.....                                      | 183        |
| 12.8.2 Receiver configuration .....                           | 183        |
| 12.8.3 Start bit and noise detection .....                    | 184        |
| 12.9 Tx/Rx swap .....                                         | 185        |
| 12.10 Interrupts .....                                        | 186        |
| 12.11 I/O pin control.....                                    | 186        |
| 12.12 USART registers.....                                    | 186        |
| 12.12.1 Status register (USART_STS) .....                     | 187        |
| 12.12.2 Data register (USART_DT).....                         | 188        |
| 12.12.3 Baud rate register (USART_BAUDR) .....                | 188        |
| 12.12.4 Control register 1 (USART_CTRL1) .....                | 189        |
| 12.12.5 Control register 2 (USART_CTRL2) .....                | 191        |
| 12.12.6 Control register 3 (USART_CTRL3) .....                | 192        |
| 12.12.7 Guard time and divider register (USART_GDIV) .....    | 194        |
| 12.12.8 Receiver timeout detection register (USART_RTOV)..... | 194        |
| 12.12.9 Interrupt flag clear register (USART_IFC) .....       | 194        |
| <b>13 Serial peripheral interface (SPI).....</b>              | <b>195</b> |
| 13.1 SPI introduction .....                                   | 195        |
| 13.2 Functional overview .....                                | 195        |
| 13.2.1 SPI overview.....                                      | 195        |
| 13.2.2 Full-duplex/half-duplex mode selector .....            | 197        |

|                                                                                     |            |
|-------------------------------------------------------------------------------------|------------|
| 13.2.3 Chip select controller.....                                                  | 199        |
| 13.2.4 SPI_SCK controller .....                                                     | 200        |
| 13.2.5 CRC .....                                                                    | 200        |
| 13.2.6 DMA transfer.....                                                            | 201        |
| 13.2.7 TI mode overview .....                                                       | 202        |
| 13.2.8 Transmitter .....                                                            | 202        |
| 13.2.9 Receiver .....                                                               | 203        |
| 13.2.10 Motorola mode .....                                                         | 203        |
| 13.2.11 TI mode communication timings .....                                         | 206        |
| 13.2.12 Interrupts .....                                                            | 207        |
| 13.2.13 IO pin control .....                                                        | 207        |
| <b>13.3 I<sup>2</sup>S functional description .....</b>                             | <b>207</b> |
| 13.3.1 I <sup>2</sup> S introduction .....                                          | 207        |
| 13.3.2 I <sup>2</sup> S full-duplex mode .....                                      | 208        |
| 13.3.3 Operating mode selection .....                                               | 209        |
| 13.3.4 Audio protocol selector .....                                                | 211        |
| 13.3.5 I2S_CLK controller .....                                                     | 212        |
| 13.3.6 DMA transfer.....                                                            | 213        |
| 13.3.7 Transmitter/Receiver .....                                                   | 213        |
| 13.3.8 I <sup>2</sup> S communication timings .....                                 | 214        |
| 13.3.9 Interrupts.....                                                              | 215        |
| 13.3.10 IO pin control .....                                                        | 215        |
| <b>13.4 SPI registers .....</b>                                                     | <b>215</b> |
| 13.4.1 SPI control register 1 (SPI_CTRL1) (Not used in I <sup>2</sup> S mode) ..... | 216        |
| 13.4.2 SPI control register 2 (SPI_CTRL2) .....                                     | 217        |
| 13.4.3 SPI status register (SPI_STS).....                                           | 218        |
| 13.4.4 SPI data register (SPI_DT) .....                                             | 218        |
| 13.4.5 SPICRC register (SPI_CPOLY) (Not used in I <sup>2</sup> S mode).....         | 219        |
| 13.4.6 SPIRxCRC register (SPI_RCRC) (Not used in I <sup>2</sup> S mode) .....       | 219        |
| 13.4.7 SPITxCRC register (SPI_TCRC).....                                            | 219        |
| 13.4.8 SPI_I2S register (SPI_I2SCTRL) .....                                         | 219        |
| 13.4.9 SPI_I2S prescaler register (SPI_I2SCLKP) .....                               | 220        |
| <b>14 Full-duplicated I<sup>2</sup>S interface (I<sup>2</sup>SF) .....</b>          | <b>221</b> |
| 14.1 I <sup>2</sup> SF interface introduction .....                                 | 221        |

|                                                                      |            |
|----------------------------------------------------------------------|------------|
| 14.2 I <sup>2</sup> SF functional overview .....                     | 221        |
| 14.2.1 I <sup>2</sup> SF full duplex mode.....                       | 221        |
| 14.2.2 I <sup>2</sup> SF master clock sources .....                  | 222        |
| 14.2.3 PCM mode .....                                                | 223        |
| 14.2.4 Interrupts .....                                              | 224        |
| 14.2.5 IO pin control .....                                          | 224        |
| 14.2.6 Special notes on I <sup>2</sup> SF usage.....                 | 224        |
| 14.3 I <sup>2</sup> SF registers .....                               | 225        |
| 14.3.1 I <sup>2</sup> SF control register 2 (I2SF_CTRL2) .....       | 225        |
| 14.3.2 I <sup>2</sup> SF status register (I2SF_STS) .....            | 225        |
| 14.3.3 I <sup>2</sup> SF data register (I2SF_DT).....                | 226        |
| 14.3.4 I <sup>2</sup> SF configuration register (I2SF_I2SCTRL) ..... | 226        |
| 14.3.5 I <sup>2</sup> SF prescaler register (I2SF_I2SCLKP) .....     | 227        |
| 14.3.6 I <sup>2</sup> SF additional register (I2SF_MISC1) .....      | 227        |
| <b>15 Timer .....</b>                                                | <b>228</b> |
| 15.1 Basic timers (TMR6 and TMR7) .....                              | 229        |
| 15.1.1 TMR6 and TMR7 introduction.....                               | 229        |
| 15.1.2 TMR6 and TMR7 main features .....                             | 229        |
| 15.1.3 TMR6 and TMR7 functional overview.....                        | 229        |
| 15.1.3.1 Counting clock.....                                         | 229        |
| 15.1.3.2 Counting mode .....                                         | 229        |
| 15.1.3.3 Debug mode .....                                            | 231        |
| 15.1.4 TMR6 and TMR7 registers .....                                 | 231        |
| 15.1.4.1 TMR6 and TMR7 control register 1 (TMRx_CTRL1).....          | 231        |
| 15.1.4.2 TMR6 and TMR7 control register 2 (TMRx_CTRL2).....          | 232        |
| 15.1.4.3 TMR6 and TMR7 DMA/interrupt enable register (TMRx_IDEN) ..  | 232        |
| 15.1.4.4 TMR6 and TMR7 interrupt status register (TMRxISTS) .....    | 232        |
| 15.1.4.5 TMR6 and TMR7 software event register (TMRx_SWEVT) .....    | 232        |
| 15.1.4.6 TMR6 and TMR7 counter value (TMRx_CVAL) .....               | 232        |
| 15.1.4.7 TMR6 and TMR7 division (TMRx_DIV) .....                     | 232        |
| 15.1.4.8 TMR6 and TMR7 period register (TMRx_PR) .....               | 233        |
| 15.2 General-purpose timers (TMR2 to TMR4).....                      | 233        |
| 15.2.1 TMR2 to TMR4 introduction .....                               | 233        |
| 15.2.2 TMR2 to TMR4 main features.....                               | 233        |
| 15.2.3 TMR2 to TMR4 functional overview .....                        | 233        |

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| 15.2.3.1 Counting clock.....                                      | 233 |
| 15.2.3.2 Counting mode .....                                      | 237 |
| 15.2.3.3 TMR input function.....                                  | 240 |
| 15.2.3.4 TMR output function.....                                 | 242 |
| 15.2.3.5 TMR synchronization.....                                 | 245 |
| 15.2.3.6 TMR DMA.....                                             | 247 |
| 15.2.3.7 Debug mode .....                                         | 248 |
| 15.2.4 TMR2 to TMR4 registers .....                               | 248 |
| 15.2.4.1 TMRx control register 1 (TMRx_CTRL1).....                | 249 |
| 15.2.4.2 TMRx control register 2 (TMRx_CTRL2).....                | 250 |
| 15.2.4.3 TMRx slave timer control register (TMRx_STCTRL) .....    | 250 |
| 15.2.4.4 TMRx DMA/interrupt enable register (TMRx_IDEN) .....     | 252 |
| 15.2.4.5 TMRx interrupt status register (TMRxISTS) .....          | 252 |
| 15.2.4.6 TMRx software event register (TMRx_SWEVT) .....          | 253 |
| 15.2.4.7 TMRx channel mode register 1 (TMRx_CM1).....             | 254 |
| 15.2.4.8 TMRx channel mode register 2 (TMRx_CM2).....             | 256 |
| 15.2.4.9 TMRx channel control register (TMRx_CCTRL).....          | 257 |
| 15.2.4.10 TMRx counter value register (TMRx_CVAL) .....           | 258 |
| 15.2.4.11 TMRx frequency division value register (TMRx_DIV) ..... | 258 |
| 15.2.4.12 TMRx period register (TMRx_PR) .....                    | 258 |
| 15.2.4.13 TMRx channel 1 data register (TMRx_C1DT).....           | 258 |
| 15.2.4.14 TMRx channel 2 data register (TMRx_C2DT).....           | 258 |
| 15.2.4.15 TMRx channel 3 data register (TMRx_C3DT).....           | 258 |
| 15.2.4.16 TMRx channel 4 data register (TMRx_C4DT).....           | 259 |
| 15.2.4.17 TMRx DMA control register (TMRx_DMACTRL) .....          | 259 |
| 15.2.4.18 TMRx DMA data register (TMRx_DMADT) .....               | 259 |
| 15.2.4.19 TMR2 channel input remap register (TMR2_RMP).....       | 259 |
| 15.3 General-purpose timer (TMR9).....                            | 260 |
| 15.3.1 TMR9 introduction .....                                    | 260 |
| 15.3.2 TMR9 main features .....                                   | 260 |
| 15.3.3 TMR9 functional overview .....                             | 260 |
| 15.3.3.1 Counting clock.....                                      | 260 |
| 15.3.3.2 Counting mode .....                                      | 263 |
| 15.3.3.3 TMR input function.....                                  | 266 |
| 15.3.3.4 TMR output function.....                                 | 268 |
| 15.3.3.5 TMR brake function .....                                 | 271 |
| 15.3.3.6 TMR synchronization.....                                 | 272 |
| 15.3.3.7 TMR DMA.....                                             | 274 |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| 15.3.3.8 Debug mode .....                                               | 274 |
| 15.3.4 TMR9 registers .....                                             | 274 |
| 15.3.4.1 TMR9 control register 1 (TMR9_CTRL1) .....                     | 275 |
| 15.3.4.2 TMR9 control register 2 (TMR9_CTRL2) .....                     | 275 |
| 15.3.4.3 TMR9 slave timer control register (TMR9_STCTRL) .....          | 276 |
| 15.3.4.4 TMR9 DMA/interrupt enable register (TMR9_IDEN).....            | 277 |
| 15.3.4.5 TMR9 interrupt status register (TMR9ISTS) .....                | 277 |
| 15.3.4.6 TMR9 software event register (TMR9_SWEVT).....                 | 278 |
| 15.3.4.7 TMR9 channel mode register 1 (TMR9_CM1) .....                  | 279 |
| 15.3.4.8 TMR9 channel control register (TMR9_CCTRL) .....               | 281 |
| 15.3.4.9 TMR9 counter value register (TMR9_CVAL) .....                  | 283 |
| 15.3.4.10 TMR9 division value register (TMR9_DIV).....                  | 283 |
| 15.3.4.11 TMR9 period register (TMR9_PR).....                           | 283 |
| 15.3.4.12 TMR9 repetition period register (TMR9_RPR).....               | 283 |
| 15.3.4.13 TMR9 channel 1 data register (TMR9_C1DT) .....                | 283 |
| 15.3.4.14 TMR9 channel 2 data register (TMR9_C2DT) .....                | 283 |
| 15.3.4.15 TMR9 break register (TMR9_BRK).....                           | 284 |
| 15.3.4.16 TMR9 DMA control register (TMR9_DMACTRL) .....                | 285 |
| 15.3.4.17 TMR9 DMA data register (TMR9_DMADT) .....                     | 285 |
| 15.4 General-purpose timers (TMR10/11/13/14) .....                      | 286 |
| 15.4.1 TMRx introduction .....                                          | 286 |
| 15.4.2 TMRx main features .....                                         | 286 |
| 15.4.3 TMRx functional overview .....                                   | 286 |
| 15.4.3.1 Counting clock.....                                            | 286 |
| 15.4.3.2 Counting mode .....                                            | 287 |
| 15.4.3.3 TMR input function.....                                        | 290 |
| 15.4.3.4 TMR output function.....                                       | 291 |
| 15.4.3.5 TMR brake function.....                                        | 294 |
| 15.4.3.6 TMR DMA .....                                                  | 295 |
| 15.4.3.7 Debug mode .....                                               | 295 |
| 15.4.4 TMRx registers.....                                              | 296 |
| 15.4.4.1 TMRx control register 1 (TMRx_CTRL1) (x=10/11/13/14).....      | 296 |
| 15.4.4.2 TMRx control register 2 (TMRx_CTRL2) (x=10/11/13/14).....      | 297 |
| 15.4.4.3 TMRx DMA/interrupt enable register (TMRx_IDEN) (x=10/11/13/14) | 297 |
| 15.4.4.4 TMRx interrupt status register (TMRxISTS) (x=10/11/13/14) ...  | 298 |
| 15.4.4.5 TMRx software event register (TMRx_SWEVT) (x=10/11/13/14) 298  |     |
| 15.4.4.6 TMRx channel mode register 1 (TMRx_CM1) (x=10/11/13/14) ...    | 299 |
| 15.4.4.7 TMRx Channel control register (TMRx_CCTRL) (x=10/11/13/14) 300 |     |

|                                                                        |            |
|------------------------------------------------------------------------|------------|
| 15.4.4.8 TMRx counter value register (TMRx_CVAL) (x=10/11/13/14) ....  | 303        |
| 15.4.4.9 TMRx division value register (TMRx_DIV) (x=10/11/13/14) ..... | 303        |
| 15.4.4.10 TMRx period register (TMRx_PR) (x=10/11/13/14) .....         | 303        |
| 15.4.4.11 TMRx repetition period register (TMRx_RPR) (x=10/11/13/14)   | 303        |
| 15.4.4.12 TMRx channel 1 data register (TMRx_C1DT) (x=10/11/13/14)     | 303        |
| 15.4.4.13 TMRx brake register (TMRx_BRK) (x=10/11/13/14) .....         | 303        |
| 15.4.4.14 TMRX DMA control register (TMRX_DMACTRL) (X=10/11/13/14)     | 305        |
| 15.4.4.15 TMRx DMA data register (TMRx_DMADT) (X=10/11/13/14) ...      | 305        |
| 15.4.4.16 TMR14 channel input remap register (TMRx_RMP) .....          | 305        |
| <b>15.5 Advanced-control timer (TMR1).....</b>                         | <b>306</b> |
| 15.5.1 TMR1 introduction .....                                         | 306        |
| 15.5.2 TMR1 main features .....                                        | 306        |
| 15.5.3 TMR1 functional overview .....                                  | 306        |
| 15.5.3.1 Counting clock.....                                           | 306        |
| 15.5.3.2 Counting mode .....                                           | 309        |
| 15.5.3.3 TMR input function.....                                       | 314        |
| 15.5.3.4 TMR output function.....                                      | 316        |
| 15.5.3.5 TMR brake function .....                                      | 320        |
| 15.5.3.6 TMR synchronization.....                                      | 321        |
| 15.5.3.7 TMR DMA.....                                                  | 323        |
| 15.5.3.8 Debug mode .....                                              | 323        |
| 15.5.4 TMR1 registers .....                                            | 323        |
| 15.5.4.1 TMR1 control register 1 (TMR1_CTRL1) .....                    | 324        |
| 15.5.4.2 TMR1 control register 2 (TMR1_CTRL2) .....                    | 325        |
| 15.5.4.3 TMR1 slave timer control register (TMR1_STCTRL).....          | 325        |
| 15.5.4.4 TMR1 DMA/interrupt enable register (TMR1_IDEN).....           | 327        |
| 15.5.4.5 TMR1 interrupt status register (TMR1ISTS) .....               | 327        |
| 15.5.4.6 TMR1 software event register (TMR1_SWEVT).....                | 328        |
| 15.5.4.7 TMR1 channel mode register1 (TMR1_CM1) .....                  | 329        |
| 15.5.4.8 TMR1 channel mode register 2 (TMR1_CM2) .....                 | 331        |
| 15.5.4.9 TMR1 channel control register (TMR1_CCTRL) .....              | 332        |
| 15.5.4.10 TMR1 counter value register (TMR1_CVAL) .....                | 334        |
| 15.5.4.11 TMR1 division value register (TMR1_DIV) .....                | 334        |
| 15.5.4.12 TMR1 period register (TMR1_PR).....                          | 334        |
| 15.5.4.13 TMR1 repetition period register (TMR1_RPR).....              | 334        |
| 15.5.4.14 TMR1 channel 1 data register (TMR1_C1DT) .....               | 334        |
| 15.5.4.15 TMR1 channel 2 data register (TMR1_C2DT) .....               | 334        |
| 15.5.4.16 TMR1 channel 3 data register (TMR1_C3DT) .....               | 335        |

|           |                                                |            |
|-----------|------------------------------------------------|------------|
| 15.5.4.17 | TMR1 channel 4 data register (TMRx_C4DT).....  | 335        |
| 15.5.4.18 | TMR1 brake register (TMR1_BRK).....            | 335        |
| 15.5.4.19 | TMR1 DMA control register (TMR1_DMACTRL) ..... | 337        |
| 15.5.4.20 | TMR1 DMA data register (TMR1_DMADT).....       | 337        |
| <b>16</b> | <b>Window watchdog timer (WWDT) .....</b>      | <b>337</b> |
| 16.1      | WWDT introduction .....                        | 337        |
| 16.2      | WWDT main features .....                       | 337        |
| 16.3      | WWDT functional overview .....                 | 337        |
| 16.4      | Debug mode.....                                | 338        |
| 16.5      | WWDT registers .....                           | 339        |
| 16.5.1    | Control register (WWDT_CTRL) .....             | 339        |
| 16.5.2    | Configuration register (WWDT_CFG) .....        | 339        |
| 16.5.3    | Status register (WWDT_STS).....                | 339        |
| <b>17</b> | <b>Watchdog timer (WDT) .....</b>              | <b>340</b> |
| 17.1      | WDT introduction .....                         | 340        |
| 17.2      | WDT main features .....                        | 340        |
| 17.3      | WDT functional overview .....                  | 340        |
| 17.4      | Debug mode.....                                | 341        |
| 17.5      | WDT registers .....                            | 341        |
| 17.5.1    | Command register (WDT_CMD) .....               | 342        |
| 17.5.2    | Divider register (WDT_DIV).....                | 342        |
| 17.5.3    | Reload register (WDT_RLD).....                 | 342        |
| 17.5.4    | Status register (WDT_STS).....                 | 342        |
| 17.5.5    | Window register (WDT_WIN).....                 | 343        |
| <b>18</b> | <b>Enhanced real-time clock (ERTC) .....</b>   | <b>343</b> |
| 18.1      | ERTC introduction.....                         | 343        |
| 18.2      | ERTC main features .....                       | 343        |
| 18.3      | ERTC functional overview.....                  | 344        |
| 18.3.1    | ERTC clocks .....                              | 344        |
| 18.3.2    | ERTC initialization.....                       | 344        |
| 18.3.3    | Periodic automatic wakeup .....                | 346        |
| 18.3.4    | ERTC calibration .....                         | 346        |

|                                                                     |            |
|---------------------------------------------------------------------|------------|
| 18.3.5 Reference clock detection .....                              | 347        |
| 18.3.6 Time stamp function .....                                    | 347        |
| 18.3.7 Tamper detection .....                                       | 348        |
| 18.3.8 Multiplexed function output .....                            | 348        |
| 18.3.9 ERTC wakeup .....                                            | 349        |
| <b>18.4 ERTC registers .....</b>                                    | <b>350</b> |
| 18.4.1 ERTC time register (ERTC_TIME) .....                         | 350        |
| 18.4.2 ERTC date register (ERTC_DATE) .....                         | 351        |
| 18.4.3 ERTC control register (ERTC_CTRL) .....                      | 351        |
| 18.4.4 ERTC initialization and status register (ERTC_STS) .....     | 352        |
| 18.4.5 ERTC divider register (ERTC_DIV) .....                       | 354        |
| 18.4.6 ERTC wakeup timer register (ERTC_WAT) .....                  | 354        |
| 18.4.7 ERTC alarm clock A register (ERTC_ALA) .....                 | 354        |
| 18.4.8 ERTC alarm clock B register (ERTC_ALB) .....                 | 354        |
| 18.4.9 ERTC write protection register (ERTC_WP) .....               | 355        |
| 18.4.10 ERTC subsecond register (ERTC_SBS) .....                    | 355        |
| 18.4.11 ERTC time adjustment register (ERTC_TADJ) .....             | 355        |
| 18.4.12 ERTC time stamp time register (ERTC_TSTM) .....             | 355        |
| 18.4.13 ERTC time stamp date register (ERTC_TS DT) .....            | 356        |
| 18.4.14 ERTC time stamp subsecond register (ERTC_TSSBS) .....       | 356        |
| 18.4.15 ERTC smooth calibration register (ERTC_SCAL) .....          | 356        |
| 18.4.16 ERTC tamper configuration register (ERTC_TAMP) .....        | 357        |
| 18.4.17 ERTC alarm clock A subsecond register (ERTC_ALASBS) .....   | 358        |
| 18.4.18 ERTC alarm clock B subsecond register (ERTC_ALBSBS) .....   | 358        |
| 18.4.19 ERTC battery powered domain data register (ERTC_BPRx) ..... | 358        |
| <b>19 Analog-to-digital converter (ADC).....</b>                    | <b>359</b> |
| 19.1 ADC introduction .....                                         | 359        |
| 19.2 ADC main features.....                                         | 359        |
| 19.3 ADC structure.....                                             | 360        |
| 19.4 ADC functional overview.....                                   | 361        |
| 19.4.1 Channel management.....                                      | 361        |
| 19.4.1.1 Internal temperature sensor .....                          | 361        |
| 19.4.1.2 Internal reference voltage .....                           | 361        |
| 19.4.2 ADC operation process .....                                  | 361        |

|                                                                                    |            |
|------------------------------------------------------------------------------------|------------|
| 19.4.2.1 Power-on and calibration .....                                            | 362        |
| 19.4.2.2 Trigger .....                                                             | 363        |
| 19.4.2.3 Sampling and conversion sequence .....                                    | 363        |
| 19.4.3 Conversion sequence management .....                                        | 364        |
| 19.4.3.1 Sequence mode .....                                                       | 364        |
| 19.4.3.2 Preempted group automatic conversion mode .....                           | 364        |
| 19.4.3.3 Repetition mode .....                                                     | 365        |
| 19.4.3.4 Partition mode .....                                                      | 365        |
| 19.4.4 Oversampling .....                                                          | 366        |
| 19.4.4.1 Oversampling of ordinary group of channels .....                          | 366        |
| 19.4.4.2 Oversampling of preempted group of channels .....                         | 367        |
| 19.4.5 Data management .....                                                       | 368        |
| 19.4.5.1 Data alignment .....                                                      | 368        |
| 19.4.5.2 Data read .....                                                           | 368        |
| 19.4.6 Voltage monitoring .....                                                    | 368        |
| 19.4.7 Status flag and interrupts .....                                            | 369        |
| 19.5 ADC registers .....                                                           | 369        |
| 19.5.1 ADC status register (ADC_STS) .....                                         | 370        |
| 19.5.2 ADC control register 1 (ADC_CTRL1) .....                                    | 370        |
| 19.5.3 ADC control register 2 (ADC_CTRL2) .....                                    | 372        |
| 19.5.4 ADC sampling time register 1 (ADC_SPT1) .....                               | 373        |
| 19.5.5 ADC sampling time register 2 (ADC_SPT2) .....                               | 375        |
| 19.5.6 ADC preempted channel data offset register x<br>(ADC_PCDTOx) (x=1..4) ..... | 377        |
| 19.5.7 ADC voltage monitoring high threshold register (ADC_VVHB) .....             | 377        |
| 19.5.8 ADC voltage monitor low threshold register (ADC_VWLB) .....                 | 377        |
| 19.5.9 ADC ordinary sequence register 1 (ADC_OSQ1) .....                           | 377        |
| 19.5.10 ADC ordinary sequence register 2 (ADC_OSQ2) .....                          | 377        |
| 19.5.11 ADC ordinary sequence register 3 (ADC_OSQ3) .....                          | 378        |
| 19.5.12 ADC preempted sequence register (ADC_PSQ) .....                            | 378        |
| 19.5.13 ADC preempted data register x (ADC_PDTx) (x=1..4) .....                    | 378        |
| 19.5.14 ADC ordinary data register (ADC_ODT) .....                                 | 378        |
| 19.5.15 ADC oversampling register (ADC_OVSP) .....                                 | 379        |
| 19.5.16 ADC common control register (ADC_CCTRL) .....                              | 379        |
| <b>20 Controller area network (CAN) .....</b>                                      | <b>380</b> |

|                                                                                                |     |
|------------------------------------------------------------------------------------------------|-----|
| 20.1 CAN introduction .....                                                                    | 380 |
| 20.2 CAN main features.....                                                                    | 380 |
| 20.3 Baud rate .....                                                                           | 380 |
| 20.4 Interrupt management .....                                                                | 383 |
| 20.5 Design tips .....                                                                         | 384 |
| 20.6 Functional overview .....                                                                 | 384 |
| 20.6.1 General description .....                                                               | 384 |
| 20.6.2 Operating modes .....                                                                   | 385 |
| 20.6.3 Test modes .....                                                                        | 386 |
| 20.6.4 Message filtering.....                                                                  | 386 |
| 20.6.5 Message transmission .....                                                              | 389 |
| 20.6.6 Message reception .....                                                                 | 390 |
| 20.6.7 Error management.....                                                                   | 391 |
| 20.7 CAN registers .....                                                                       | 391 |
| 20.7.1 CAN control and status registers .....                                                  | 393 |
| 20.7.1.1 CAN master control register (CAN_MCTRL) .....                                         | 393 |
| 20.7.1.2 CAN master status register (CAN_MSTS).....                                            | 394 |
| 20.7.1.3 CAN transmit status register (CAN_TSTS) .....                                         | 395 |
| 20.7.1.4 CAN receive FIFO 0 register (CAN_RF0) .....                                           | 398 |
| 20.7.1.5 CAN receive FIFO 1 register (CAN_RF1) .....                                           | 398 |
| 20.7.1.6 CAN interrupt enable register (CAN_INTEN) .....                                       | 399 |
| 20.7.1.7 CAN error status register (CAN_ESTS) .....                                            | 401 |
| 20.7.1.8 CAN bit timing register (CAN_BTMG) .....                                              | 401 |
| 20.7.2 CAN mailbox registers .....                                                             | 402 |
| 20.7.2.1 Transmit mailbox identifier register (CAN_TMIx) (x=0..2) .....                        | 402 |
| 20.7.2.2 Transmit mailbox data length and time stamp register<br>(CAN_TMCx) (x=0..2).....      | 403 |
| 20.7.2.3 Transmit mailbox data low register (CAN_TMDTLx) (x=0..2) ....                         | 403 |
| 20.7.2.4 Transmit mailbox data high register (CAN_TMDTHx) (x=0..2) ...                         | 403 |
| 20.7.2.5 Receive FIFO mailbox identifier register (CAN_RFIx) (x=0..1) ..                       | 403 |
| 20.7.2.6 Receive FIFO mailbox data length and time stamp register<br>(CAN RFCx) (x=0..1) ..... | 404 |
| 20.7.2.7 Receive FIFO mailbox data low register (CAN_RFDTLx) (x=0..1)                          | 404 |
| 20.7.2.8 Receive FIFO mailbox data high register (CAN_RFDTThx) (x=0..1)                        | 404 |
| 20.7.3 CAN filter registers .....                                                              | 404 |
| 20.7.3.1 CAN filter control register (CAN_FCTRL) .....                                         | 404 |

|                                                                              |            |
|------------------------------------------------------------------------------|------------|
| 20.7.3.2 CAN filter mode configuration register (CAN_FMCFG) .....            | 404        |
| 20.7.3.3 CAN filter bit width configuration register (CAN_FBWCFG).....       | 405        |
| 20.7.3.4 CAN filter FIFO association register (CAN_FRF) .....                | 405        |
| 20.7.3.5 CAN filter activation control register (CAN_FACFG).....             | 405        |
| 20.7.3.6 CAN filter bank i filter bit register (CAN_FiFBx) (i=0..13; x=1..2) | 405        |
| <b>21 USB full-speed/high-speed device interface (OTGFS/HS) .....</b>        | <b>406</b> |
| 21.1 OTGFS/OTGHS structure .....                                             | 406        |
| 21.2 OTGFS/HS functional description .....                                   | 407        |
| 21.3 OTGFS/HS clock and pin configuration .....                              | 408        |
| 21.3.1 OTGFS clock configuration .....                                       | 408        |
| 21.3.2 OTGHS clock configuration .....                                       | 408        |
| 21.3.3 OTGFS/HS pin configuration .....                                      | 408        |
| 21.4 OTGFS/HS interrupts .....                                               | 409        |
| 21.5 OTGFS/HS functional description .....                                   | 410        |
| 21.5.1 OTGFS/HS initialization .....                                         | 410        |
| 21.5.2 OTGFS/HS FIFO configuration .....                                     | 410        |
| 21.5.2.1 Device mode .....                                                   | 410        |
| 21.5.2.2 Host mode.....                                                      | 411        |
| 21.5.2.3 Refresh controller transmit FIFO .....                              | 412        |
| 21.5.3 OTGFS /HS host mode .....                                             | 412        |
| 21.5.3.1 Host initialization .....                                           | 413        |
| 21.5.3.2 OTGFS/HS channel initialization .....                               | 413        |
| 21.5.3.3 Halting a channel.....                                              | 413        |
| 21.5.3.4 Queue depth.....                                                    | 414        |
| 21.5.3.5 Special cases .....                                                 | 415        |
| 21.5.3.6 Host HFIR feature .....                                             | 416        |
| 21.5.3.7 Initialize bulk and control IN transfers.....                       | 417        |
| 21.5.3.8 Initialize bulk and control OUT/SETUP transfers .....               | 419        |
| 21.5.3.9 Initialize interrupt IN transfers.....                              | 421        |
| 21.5.3.10 Initialize interrupt OUT transfers .....                           | 423        |
| 21.5.3.11 Initialize isochronous IN transfers .....                          | 425        |
| 21.5.3.12 Initialize isochronous OUT transfers .....                         | 427        |
| 21.5.4 OTGFS/HS device mode .....                                            | 428        |
| 21.5.4.1 Device initialization .....                                         | 428        |
| 21.5.4.2 Endpoint initialization on USB reset.....                           | 428        |
| 21.5.4.3 Endpoint initialization on enumeration completion.....              | 429        |

|                                                                                                                                    |            |
|------------------------------------------------------------------------------------------------------------------------------------|------------|
| 21.5.4.4 Endpoint initialization on SetAddress command .....                                                                       | 429        |
| 21.5.4.5 Endpoint initialization on SetConfiguration/SetInterface command                                                          | 429        |
| 21.5.4.6 Endpoint activation .....                                                                                                 | 430        |
| 21.5.4.7 USB endpoint deactivation.....                                                                                            | 430        |
| 21.5.4.8 Control write transfers (SETUP/Data OUT/Status IN) .....                                                                  | 430        |
| 21.5.4.9 Control read transfers (SETUP/Data IN/Status OUT).....                                                                    | 431        |
| 21.5.4.10 Control transfers (SETUP/Status IN).....                                                                                 | 431        |
| 21.5.4.11 Read FIFO packets .....                                                                                                  | 431        |
| 21.5.4.12 OUT data transfers .....                                                                                                 | 433        |
| 21.5.4.13 IN data transfers .....                                                                                                  | 434        |
| 21.5.4.14 Non-periodic (bulk and control) IN data transfers.....                                                                   | 435        |
| 21.5.4.15 Non-synchronous OUT data transfers .....                                                                                 | 436        |
| 21.5.4.16 Synchronous OUT data transfers.....                                                                                      | 438        |
| 21.5.4.17 Enable synchronous endpoints.....                                                                                        | 440        |
| 21.5.4.18 Incomplete isochronous OUT data transfers .....                                                                          | 441        |
| 21.5.4.19 Incomplete isochronous IN data transfers .....                                                                           | 442        |
| 21.5.4.20 Periodic IN (interrupt and isochronous) data transfers.....                                                              | 442        |
| <b>21.6 OTGFS/HS control and status registers .....</b>                                                                            | <b>444</b> |
| 21.6.1 CSR register map.....                                                                                                       | 444        |
| 21.6.2 OTGFS/HS register address map .....                                                                                         | 445        |
| 21.6.3 OTGFS/HS global registers.....                                                                                              | 450        |
| 21.6.3.1 OTGFS/HS status and control register (OTGFS/HS_GOTGCTL)                                                                   | 451        |
| 21.6.3.2 OTGFS/HS interrupt status control register (OTGFS/HS_GOTGINT)                                                             | 451        |
| 21.6.3.3 OTGFS/HS AHB configuration register (OTGFS/HS_GAHBCFG)                                                                    | 451        |
| 21.6.3.4 OTGFS/HS USB configuration register (OTGFS/HS_GUSBCFG)                                                                    | 452        |
| 21.6.3.5 OTGFS/HS reset register (OTGFS/HS_GRSTCTL) .....                                                                          | 453        |
| 21.6.3.6 OTGFS/HS interrupt register (OTGFS/HS_GINTSTS) .....                                                                      | 455        |
| 21.6.3.7 OTGFS/HS interrupt mask register (OTGFS/HS_GINTMSK) .....                                                                 | 458        |
| 21.6.3.8 OTGFS/HS receive status debug read/OTG status read and POP registers (OTGFS/HS_GRXSTSR / OTGFS/HS_GRXSTSP) .....          | 459        |
| 21.6.3.9 OTGFS/HS receive FIFO size register (OTGFS/HS_GRXFSIZ) .                                                                  | 460        |
| 21.6.3.10 OTGFS/HS non-periodic Tx FIFO size<br>(OTGFS/HS_GNPTXFSIZ)/Endpoint 0 Tx FIFO size registers<br>(OTGFS/HS_DIEPTXF0)..... | 460        |
| 21.6.3.11 OTGFS/HS non-periodic Tx FIFO size/request queue status register<br>(OTGFS/HS_GNPTXSTS) .....                            | 461        |
| 21.6.3.12 OTGFS/HS general controller configuration register<br>(OTGFS_GCCFG) .....                                                | 461        |
| 21.6.3.13 OTGFS/HS controller ID register (OTGFS/HS_GUID) .....                                                                    | 462        |

|                                                                                                                                                       |     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 21.6.3.14 OTGFS/HS host periodic Tx FIFO size register<br>(OTGFS/HS_HPTXFSIZ).....                                                                    | 462 |
| 21.6.3.15 OTGFS/HS device IN endpoint Tx FIFO size register<br>(OTGFS/HS_DIEPTXF <sub>n</sub> ) (x=1...15, where n is the FIFO number) .....          | 463 |
| 21.6.4 Host-mode registers .....                                                                                                                      | 463 |
| 21.6.4.1 OTGFS/HS host mode configuration register (OTGFS/HS_HCFG)                                                                                    | 463 |
| 21.6.4.2 OTGFS/HS host frame interval register (OTGFS/HS_HFIR) .....                                                                                  | 463 |
| 21.6.4.3 OTGFS/HS host frame number/frame time remaining register<br>(OTGFS/HS_HFNUM).....                                                            | 464 |
| 21.6.4.4 OTGFS/HS host periodic Tx FIFO/request queue register<br>(OTGFS/HS_HPTXSTS) .....                                                            | 464 |
| 21.6.4.5 OTGFS/HS host all channels interrupt register (OTGFS/HS_HAINT)                                                                               | 465 |
| 21.6.4.6 OTGFS/HS host all channels interrupt mask register<br>(OTGFS/HS_HAINTMSK).....                                                               | 465 |
| 21.6.4.7 OTGFS/HS host port control and status register<br>(OTGFS/HS_HPRT) .....                                                                      | 465 |
| 21.6.4.8 OTGFS/HS host channel <sub>x</sub> characteristics register<br>(OTGFS/HS_HCCCHAR <sub>x</sub> ) (x = 0...15, where x= channel number) .....  | 467 |
| 21.6.4.9 OTGFS/HS host channel <sub>x</sub> split register (OTGFS/HS_HCSPLTx) (x =<br>0...15, where x= channel number) .....                          | 468 |
| 21.6.4.10 OTGFS/HS host channel <sub>x</sub> interrupt register (OTGFS/HS_HCINT <sub>x</sub> ) (x<br>= 0...15, where x= channel number) .....         | 469 |
| 21.6.4.11 OTGFS/HS host channel <sub>x</sub> interrupt mask register<br>(OTGFS/HS_HCINTMSK <sub>x</sub> ) (x = 0...15, where x= channel number) ..... | 470 |
| 21.6.4.12 OTGFS/HS host channel <sub>x</sub> transfer size register<br>(OTGFS/HS_HCTSIZ <sub>x</sub> ) (x = 0...15, where x= channel number) .....    | 470 |
| 21.6.4.13 OTGHS host channel-x DMA address register (OTGHS_HCDMAX) (x<br>= 0...15, where x= channel number) .....                                     | 470 |
| 21.6.5 Device-mode registers .....                                                                                                                    | 471 |
| 21.6.5.1 OTGFS/HS device configuration register (OTGFS/HS_DCFG) ...                                                                                   | 471 |
| 21.6.5.2 OTGFS/HS device control register (OTGFS/HS_DCTL) .....                                                                                       | 471 |
| 21.6.5.3 OTGFS/HS device status register (OTGFS/HS_DSTS) .....                                                                                        | 473 |
| 21.6.5.4 OTGFS/HS device OTGFSIN endpoint common interrupt mask register<br>(OTGFS/HS_DIEPMSK).....                                                   | 473 |
| 21.6.5.5 OTGFS/HS device OUT endpoint common interrupt mask register<br>(OTGFS/HS_DOEPMSK) .....                                                      | 474 |
| 21.6.5.6 OTGFS/HS device all endpoints interrupt mask register<br>(OTGFS/HS_DAINT) .....                                                              | 475 |
| 21.6.5.7 OTGFS/HS all endpoints interrupt mask register<br>(OTGFS/HS_DAINTMSK).....                                                                   | 475 |

|                                                                                                                                        |            |
|----------------------------------------------------------------------------------------------------------------------------------------|------------|
| 21.6.5.8 OTGFS/HS device IN endpoint FIFO empty interrupt mask register<br>(OTGFS/HS_DIEPEMPMSK) .....                                 | 475        |
| 21.6.5.9 OTGHS device all endpoints interrupt register<br>(OTGHS_DEACHINT) .....                                                       | 475        |
| 21.6.5.10 OTGHS device all endpoints interrupt register<br>(OTGHS_DEACHINTMSK) .....                                                   | 476        |
| 21.6.5.11 OTGHS device IN endpoint 1 interrupt mask register<br>(OTGHS_DIEPEACHMSK1) .....                                             | 476        |
| 21.6.5.12 OTGHS device OUT endpoint 1 interrupt mask register (OTGHS_<br>DOEPEACHMSK1)).....                                           | 476        |
| 21.6.5.13 OTGFS/HS device control IN endpoint 0 control register<br>(OTGFS/HS_DIEPCTL0).....                                           | 478        |
| 21.6.5.14 OTGFS/HS device IN endpoint-x control register<br>(OTGFS/HS_DIEPCTLx) (x=1...7, where x is endpoint number) .....            | 479        |
| 21.6.5.15 OTGFS/HS device control OUT endpoint 0 control register<br>(OTGFS/HS_DOEPCTL0) .....                                         | 481        |
| 21.6.5.16 OTGFS/HS device control OUT endpoint-x control register<br>(OTGFS/HS_DOEPCTLx) (x=1...7, where x if endpoint number).....    | 482        |
| 21.6.5.17 OTGFS/HS device IN endpoint-x interrupt register<br>(OTGFS_DIEPINTx) (x=0...7, where x if endpoint number) .....             | 484        |
| 21.6.5.18 OTGFS/HS device OUT endpoint-x interrupt register<br>(OTGFS/HS_DOEPINTx) (x=0...7, where x if endpoint number) .....         | 485        |
| 21.6.5.19 OTGFS/HS device IN endpoint 0 transfer size register<br>(OTGFS/HS_DIEPTSIZ0).....                                            | 486        |
| 21.6.5.20 OTGFS/HS device OUT endpoint 0 transfer size register<br>(OTGFS/HS_DOEPTSIZ0) .....                                          | 486        |
| 21.6.5.21 OTGFS/HS device IN endpoint-x transfer size register<br>(OTGFS/HS_DIEPTSIZx) (x=1...7, where x is endpoint number) .....     | 487        |
| 21.6.5.22 OTGHS device IN endpoint-x DMA address register<br>(OTGHS_DIEPDMAX) (x=1...7, where x is endpoint number) .....              | 487        |
| 21.6.5.23 OTGFS/HS device IN endpoint transmit FIFO status register<br>(OTGFS/HS_DTXFSTSx) (x=1...7, where x is endpoint number) ..... | 487        |
| 21.6.5.24 OTGFS/HS device OUT endpoint-x transfer size register<br>(OTGFS/HS_DOEPTSIZx) (x=1...7, where x is endpoint number) .....    | 487        |
| 21.6.5.25 OTGHS device OUT endpoint-x DMA address register<br>(OTGHS_DOEPDMAX) (x=1...7, where x is endpoint number) .....             | 488        |
| 21.6.6 Power and clock control registers .....                                                                                         | 489        |
| 21.6.6.1 OTGFS/HS power and clock gating control register<br>(OTGFS/HS_PCGCCTL) .....                                                  | 489        |
| <b>22 HICK auto clock calibration (ACC) .....</b>                                                                                      | <b>490</b> |

|           |                                               |            |
|-----------|-----------------------------------------------|------------|
| 22.1      | ACC introduction .....                        | 490        |
| 22.2      | Main features .....                           | 490        |
| 22.3      | Interrupt requests .....                      | 490        |
| 22.4      | Functional description .....                  | 490        |
| 22.5      | Principles .....                              | 492        |
| 22.6      | Register description .....                    | 493        |
| 22.6.1    | ACC register map.....                         | 493        |
| 22.6.2    | Status register (ACC_STS) .....               | 493        |
| 22.6.3    | Control register 1 (ACC_CTRL1) .....          | 493        |
| 22.6.4    | Control register 2 (ACC_CTRL2) .....          | 494        |
| 22.6.5    | Compare value 1 (ACC_C1) .....                | 495        |
| 22.6.6    | Compare value 2 (ACC_C2) .....                | 495        |
| 22.6.7    | Compare value 3 (ACC_C3) .....                | 495        |
| <b>23</b> | <b>Quad-SPI interface (QSPI).....</b>         | <b>496</b> |
| 23.1      | QSPI introduction .....                       | 496        |
| 23.2      | QSPI main features.....                       | 496        |
| 23.3      | QSPI functional overview.....                 | 496        |
| 23.3.1    | QSPI command slave port.....                  | 496        |
| 23.3.2    | CPU PIO mode.....                             | 496        |
| 23.3.3    | DMA handshake mode .....                      | 497        |
| 23.3.4    | XIP port (direct address map read/write)..... | 497        |
| 23.3.5    | XIP port prefetch .....                       | 497        |
| 23.3.6    | SPI device operation .....                    | 497        |
| 23.4      | QSPI registers .....                          | 503        |
| 23.4.1    | Command word 0 (CMD_W0) .....                 | 503        |
| 23.4.2    | Command word 1 (CMD_W1) .....                 | 503        |
| 23.4.3    | Command word 2 (CMD_W2) .....                 | 504        |
| 23.4.4    | Command word 3 (CMD_W3) .....                 | 504        |
| 23.4.5    | Control register (CTRL) .....                 | 505        |
| 23.4.6    | FIFO status register (FIFOSTS) .....          | 506        |
| 23.4.7    | Control register 2 (CTRL2).....               | 507        |
| 23.4.8    | Command status register (CMDSTS) .....        | 507        |
| 23.4.9    | Read status register (RSTS) .....             | 507        |

|           |                                              |            |
|-----------|----------------------------------------------|------------|
| 23.4.10   | Flash size register (FSIZE) (FSIZE)          | 508        |
| 23.4.11   | XIP command word 0 (XIP CMD_W0)              | 508        |
| 23.4.12   | XIP command word 1 (XIP CMD_W1)              | 508        |
| 23.4.13   | XIP command word 2 (XIP CMD_W2)              | 509        |
| 23.4.14   | XIP command word 3 (XIP CMD_W3)              | 510        |
| 23.4.15   | Control register (CTRL3)                     | 510        |
| 23.4.16   | Revision register (REV)                      | 510        |
| 23.4.17   | Data port register (DT)                      | 510        |
| <b>24</b> | <b>Infrared interface (IRTMR)</b>            | <b>511</b> |
| <b>25</b> | <b>Debug (DEBUG)</b>                         | <b>512</b> |
| 25.1      | Debug introduction                           | 512        |
| 25.2      | Debug and Trace                              | 512        |
| 25.3      | I/O pin control                              | 512        |
| 25.4      | DEGUB registers                              | 512        |
| 25.4.1    | DEBUG device ID (DEBUG_IDCODE)               | 513        |
| 25.4.2    | DEBUG control register (DEBUG_CTRL)          | 514        |
| 25.4.3    | DEBUG APB1 pause register (DEBUG_APB1_PAUSE) | 514        |
| 25.4.4    | DEBUG APB2 pause register (DEBUG_APB2_PAUSE) | 516        |
| 25.4.5    | DEBUG SERIES ID register (DEBUG_SER_ID)      | 517        |
| <b>26</b> | <b>Revision history</b>                      | <b>518</b> |

## List of figures

|                                                                            |     |
|----------------------------------------------------------------------------|-----|
| Figure 2-1 AT32F402/405 address mapping .....                              | 43  |
| Figure 3-1 Block diagram of each power supply .....                        | 48  |
| Figure 3-2 Power-on/Low voltage reset waveform.....                        | 49  |
| Figure 3-3 PVM threshold and output .....                                  | 49  |
| Figure 4-1 AT32F405 clock tree .....                                       | 55  |
| Figure 4-2 AT32F402 clock tree .....                                       | 56  |
| Figure 4-3 System reset circuit.....                                       | 58  |
| Figure 5-1 Flash memory sector erase process.....                          | 80  |
| Figure 5-2 Flash memory mass erase process .....                           | 81  |
| Figure 5-3 Flash memory programming process .....                          | 82  |
| Figure 5-4 System data area erase process .....                            | 84  |
| Figure 5-5 System data area programming process.....                       | 85  |
| Figure 6-1 GPIO basic structure.....                                       | 96  |
| Figure 6-2 IOMUXU Structure .....                                          | 98  |
| Figure 8-1 External interrupt/event controller block diagram .....         | 118 |
| Figure 9-1 DMA block diagram .....                                         | 121 |
| Figure 9-2 Re-arbitrate after request/acknowledge.....                     | 122 |
| Figure 9-3 PWIDTH: byte, MWIDTH: half-word .....                           | 123 |
| Figure 9-4 PWIDTH: half-word, MWIDTH: word .....                           | 123 |
| Figure 9-5 PWIDTH: word, MWIDTH: byte .....                                | 123 |
| Figure 9-6 DMAMUX block diagram.....                                       | 124 |
| Figure 9-7 DMAMUX request synchronized mode.....                           | 126 |
| Figure 9-8 DMAMUX event generation .....                                   | 127 |
| Figure10-1 CRC calculation unit block diagram.....                         | 138 |
| Figure 11-1 I <sup>2</sup> C bus protocol .....                            | 141 |
| Figure 11-2 I <sup>2</sup> C interface block diagram .....                 | 142 |
| Figure 11-3 Setup and hold time .....                                      | 144 |
| Figure 11-4 I <sup>2</sup> C master transmission flow .....                | 148 |
| Figure 11-5 Transfer sequence of I <sup>2</sup> C master transmitter ..... | 149 |
| Figure 11-6 I <sup>2</sup> C master receive flow .....                     | 149 |
| Figure 11-7 Transfer sequence of I <sup>2</sup> C master receiver .....    | 150 |
| Figure 11-8 10-bit address read access when READH10=1 .....                | 150 |
| Figure 11-9 10-bit address read access when READH10=0 .....                | 150 |
| Figure 11-10 I <sup>2</sup> C slave transmission flow .....                | 152 |
| Figure 11-11 I <sup>2</sup> C slave transmission timing .....              | 153 |
| Figure 11-12 I <sup>2</sup> C slave receive flow .....                     | 153 |
| Figure 11-13 I <sup>2</sup> C slave receive timing.....                    | 154 |
| Figure 11-14 SMBus master transmission flowchart.....                      | 158 |
| Figure 11-15 SMBus master transmission timing.....                         | 159 |
| Figure 11-16 SMBus master reception flowchart .....                        | 159 |
| Figure 11-17 SMBus master receive timing .....                             | 160 |
| Figure 11-18 SMBus slave transmission flow.....                            | 162 |
| Figure 11-19 SMBus slave transmission timing .....                         | 162 |

|                                                                             |     |
|-----------------------------------------------------------------------------|-----|
| Figure 11-20 SMBus slave receive flow .....                                 | 163 |
| Figure 11-21 SMBus slave receive timing .....                               | 164 |
| Figure 12-1 USART block diagram.....                                        | 173 |
| Figure 12-2 BFF and FERR detection in LIN mode .....                        | 175 |
| Figure 12-3 Smartcard frame format .....                                    | 176 |
| Figure 12-4 IrDA DATA(3/16) – normal mode .....                             | 176 |
| Figure 12-5 Hardware flow control .....                                     | 177 |
| Figure 12-6 Mute mode using Idle line or Address mark detection.....        | 178 |
| Figure 12-7 8-bit format USART synchronous mode .....                       | 178 |
| Figure 12-8 Word length configuration .....                                 | 179 |
| Figure 12-9 Stop bit configuration .....                                    | 180 |
| Figure 12-10 Variations when transmitting TDC/TDBE .....                    | 182 |
| Figure 12-11 Data sampling for noise detection.....                         | 185 |
| Figure 12-12 Tx/Rx swap.....                                                | 185 |
| Figure 12-13 USART interrupt map diagram.....                               | 186 |
| Figure 13-1 SPI block diagram .....                                         | 195 |
| Figure 13-2 Data clock timing diagram.....                                  | 197 |
| Figure 13-3 SPI two-wire unidirectional full-duplex connection .....        | 198 |
| Figure 13-4 Single-wire unidirectional receive only in SPI master mode..... | 198 |
| Figure 13-5 Single-wire unidirectional receive only in SPI slave mode ..... | 198 |
| Figure 13-6 Single-wire bidirectional half-duplex mode .....                | 199 |
| Figure 13-7 DMA data transfer with CRC enabled .....                        | 201 |
| Figure 13-8 Master full-duplex communications .....                         | 204 |
| Figure 13-9 Slave full-duplex communications.....                           | 204 |
| Figure 13-10 Master half-duplex transmit.....                               | 204 |
| Figure 13-11 Slave half-duplex receive .....                                | 205 |
| Figure 13-12 Slave half-duplex transmit.....                                | 205 |
| Figure 13-13 Master half-duplex receive .....                               | 206 |
| Figure 13-14 TI mode continous transfer .....                               | 206 |
| Figure 13-15 TI mode continous transfer with dummy CLK.....                 | 206 |
| Figure 13-16 TI mode discontinuous transfer.....                            | 206 |
| Figure 13-17 TI mode SCK and slave MISO release .....                       | 207 |
| Figure 13-18 SPI interrupts .....                                           | 207 |
| Figure 13-19 I <sup>2</sup> S block diagram .....                           | 208 |
| Figure 13-20 I <sup>2</sup> S full-duplex structure .....                   | 209 |
| Figure 13-21 I <sup>2</sup> S slave device transmission .....               | 209 |
| Figure 13-22 I <sup>2</sup> S slave device reception.....                   | 210 |
| Figure 13-23 I <sup>2</sup> S master device transmission.....               | 210 |
| Figure 13-24 I <sup>2</sup> S master device reception .....                 | 210 |
| Figure 13-25 CK & MCK source in master mode .....                           | 212 |
| Figure 13-26 Audio standard timings.....                                    | 214 |
| Figure 13-27 I <sup>2</sup> S interrupts.....                               | 215 |
| Figure 14-1 I <sup>2</sup> SF full-duplex host transmit/slave transmit..... | 221 |
| Figure 14-2 I <sup>2</sup> SF full-duplex host transmit/slave receive.....  | 221 |
| Figure 14-3 I <sup>2</sup> SF full-duplex host receive/slave transmit.....  | 222 |

|                                                                                             |     |
|---------------------------------------------------------------------------------------------|-----|
| Figure 14-4 I <sup>2</sup> S full-duplex host receive/slave receive .....                   | 222 |
| Figure 14-5 I <sup>2</sup> S master clock sources .....                                     | 223 |
| Figure 14-6 Data sampling on falling edge in PCM mode .....                                 | 223 |
| Figure 14-7 Data sampling on rising edge in PCM mode .....                                  | 223 |
| Figure 14-8 I <sup>2</sup> S interrupts .....                                               | 224 |
| Figure 15-1 Basic timer block diagram .....                                                 | 229 |
| Figure 15-2 Internal counting clock example .....                                           | 229 |
| Figure 15-3 Basic structure of a counter .....                                              | 230 |
| Figure 15-4 Overflow event when PRBEN=0 .....                                               | 230 |
| Figure 15-5 Overflow event when PRBEN=1 .....                                               | 230 |
| Figure 15-6 Counting timing diagram when the prescaler division is 3 .....                  | 230 |
| Figure 15-7 General-purpose timer block diagram .....                                       | 233 |
| Figure 15-8 Counting clock .....                                                            | 234 |
| Figure 15-9 Control circuit with CK_INT, TMRx_DIV=0x0 and TMRx_PR=0x16 .....                | 234 |
| Figure 15-10 Block diagram of external clock mode A .....                                   | 235 |
| Figure 15-11 Counting in external clock mode A, PR=0x32 and DIV=0x0 .....                   | 235 |
| Figure 15-12 Block diagram of external clock mode B .....                                   | 235 |
| Figure 15-13 Counting in external clock mode B, PR=0x32 and DIV=0x0 .....                   | 236 |
| Figure 15-14 Counter timing with prescaler value chang from 0 to 3 .....                    | 236 |
| Figure 15-15 Basic structure of a counter .....                                             | 237 |
| Figure 15-16 Overflow event when PRBEN=0 .....                                              | 237 |
| Figure 15-17 Overflow event when PRBEN=1 .....                                              | 238 |
| Figure 15-18 Counter timing diagram with internal clock divided by 3 .....                  | 238 |
| Figure 15-19 Counter timing diagram with internal clock divided by 0 and TMRx_PR=0x32 ..... | 238 |
| Figure 15-20 Encoder mode structure .....                                                   | 239 |
| Figure 15-21 Example of counter behavior in encoder interface mode (encoder mode C) .....   | 240 |
| Figure 15-22 Input/output channel 1 main circuit .....                                      | 240 |
| Figure 15-23 Channel 1 input stage .....                                                    | 240 |
| Figure 15-24 PWM input mode configuration example .....                                     | 241 |
| Figure 15-25 PWM input mode .....                                                           | 242 |
| Figure 15-26 Capture/compare channel output stage (channel 1 to 4) .....                    | 242 |
| Figure 15-27 PWM mode A in upcounting mode .....                                            | 243 |
| Figure 15-28 PWM mode B in up/down counting mode .....                                      | 243 |
| Figure 15-29 C1ORAW toggles when counter value matches C1DT value .....                     | 244 |
| Figure 15-30 One-pulse mode .....                                                           | 244 |
| Figure 15-31 Clearing CxORAW(PWM mode B) by EXT input .....                                 | 245 |
| Figure 15-32 Example of reset mode .....                                                    | 245 |
| Figure 15-33 Example of suspend mode .....                                                  | 245 |
| Figure 15-34 Example of trigger mode .....                                                  | 246 |
| Figure 15-35 Master/slave timer connection .....                                            | 246 |
| Figure 15-36 Using master timer to start slave timer .....                                  | 247 |
| Figure 15-37 Starting master and slave timers synchronously by an external trigger .....    | 247 |
| Figure 15-38 Block diagram of general-purpose TMR9 .....                                    | 260 |
| Figure 15-39 Counting clock .....                                                           | 260 |
| Figure 15-40 Control circuit with CK_INT, TMRx_DIV=0x0 and TMRx_PR=0x16 .....               | 261 |

|                                                                                                         |     |
|---------------------------------------------------------------------------------------------------------|-----|
| Figure 15-41 Block diagram of external clock mode A.....                                                | 261 |
| Figure 15-42 Counting in external clock mode A, PR=0x32 and DIV=0x0 .....                               | 262 |
| Figure 15-43 Counter timing with prescaler value chang from 0 to 3 .....                                | 262 |
| Figure 15-44 Basic structure of a counter .....                                                         | 263 |
| Figure 15-45 Overflow event when PRBEN=0.....                                                           | 263 |
| Figure 15-46 Overflow event when PRBEN=1 .....                                                          | 264 |
| Figure 15-47 Counter timing diagram with internal clock divided by 3 .....                              | 264 |
| Figure 15-48 Counter timing diagram with internal clock divided by 0 and TMR <sub>x</sub> _PR=0x32..... | 265 |
| Figure 15-49 OVFIF in upcounting mode and central-aligned mode.....                                     | 265 |
| Figure 15-50 Input/output channel 1 main circuit.....                                                   | 266 |
| Figure 15-51 Channel 1 input stage .....                                                                | 266 |
| Figure 15-52 PWM input mode configuration example .....                                                 | 267 |
| Figure 15-53 PWM input mode.....                                                                        | 268 |
| Figure 15-54 Channel 1 output stage.....                                                                | 268 |
| Figure 15-55 Channel 2 output stage.....                                                                | 268 |
| Figure 15-56 PWM mode A in upcounting mode.....                                                         | 269 |
| Figure 15-57 C1ORAW toggles when counter value matches C1DT value .....                                 | 269 |
| Figure 15-58 One-pulse mode.....                                                                        | 270 |
| Figure 15-59 Upcounting mode and PWM mode A.....                                                        | 270 |
| Figure 15-60 Complementary output with dead-time insertion .....                                        | 271 |
| Figure 15-61 TMR output control.....                                                                    | 272 |
| Figure 15-62 Example of TMR brake function.....                                                         | 272 |
| Figure 15-63 Example of reset mode .....                                                                | 273 |
| Figure 15-64 Example of suspend mode .....                                                              | 273 |
| Figure 15-65 Example of trigger mode .....                                                              | 273 |
| Figure 15-66 TMR10/11/13/14 block diagram .....                                                         | 286 |
| Figure 15-67 Counting clock.....                                                                        | 286 |
| Figure 15-68 Control circuit with CK_INT, TMR <sub>x</sub> _DIV=0x0 and PR=0x16 .....                   | 287 |
| Figure 15-69 Basic structure of a counter .....                                                         | 287 |
| Figure 15-70 Overflow event when PRBEN=0.....                                                           | 288 |
| Figure 15-71 Overflow event when PRBEN=1 .....                                                          | 288 |
| Figure 15-72 Counter timing diagram with internal clock divided by 3 .....                              | 288 |
| Figure 15-73 Counter timing diagram with internal clock divided by 0 and TMR <sub>x</sub> _PR=0x32..... | 289 |
| Figure 15-74 OVFIF in upcounting mode and central-aligned mode.....                                     | 289 |
| Figure 15-75 Input/output channel 1 main circuit .....                                                  | 290 |
| Figure 15-76 Channel 1 input stage .....                                                                | 290 |
| Figure 15-77 Channel 1 output stage .....                                                               | 291 |
| Figure 15-78 PWM mode A in upcounting mode .....                                                        | 292 |
| Figure 15-79 C1ORAW toggles when counter value matches C1DT value .....                                 | 292 |
| Figure 15-80 One-pulse mode.....                                                                        | 293 |
| Figure 15-81 Complementary output with dead-time insertion .....                                        | 293 |
| Figure 15-82 TMR output control.....                                                                    | 294 |
| Figure 15-83 Example of TMR brake function .....                                                        | 295 |
| Figure 15-84 Block diagram of advanced-control timer .....                                              | 306 |
| Figure 15-85 Counting clock.....                                                                        | 307 |

|                                                                                            |     |
|--------------------------------------------------------------------------------------------|-----|
| Figure 15-86 Control circuit with CK_INT, TMRx_DIV=0x0 and TMRx_PR=0x16.....               | 307 |
| Figure 15-87 Block diagram of external clock mode A.....                                   | 308 |
| Figure 15-88 Counting in external clock mode A, PR=0x32 and DIV=0x0 .....                  | 308 |
| Figure 15-89 Block diagram of external clock mode B.....                                   | 308 |
| Figure 15-90 Counting in external clock mode B, PR=0x32 and DIV=0x0 .....                  | 309 |
| Figure 15-91 Counter timing with prescaler value changing from 0 to 3 .....                | 309 |
| Figure 15-92 Basic structure of a counter .....                                            | 310 |
| Figure 15-93 Overflow event when PRBEN=0.....                                              | 310 |
| Figure 15-94 Overflow event when PRBEN=1 .....                                             | 310 |
| Figure 15-95 Counter timing diagram with internal clock divided by 3 .....                 | 311 |
| Figure 15-96 Counter timing diagram with internal clock divided by 0 and TMRx_PR=0x32..... | 311 |
| Figure 15-97 OVFIF behavior in upcounting mode and center-aligned mode .....               | 312 |
| Figure 15-98 Structure of encoder mode .....                                               | 312 |
| Figure 15-99 Example of encoder interface mode C .....                                     | 313 |
| Figure 15-100 Input/output channel 1 main circuit .....                                    | 314 |
| Figure 15-101 Channel 1 input stage .....                                                  | 314 |
| Figure 15-102 PWM input mode configuration example .....                                   | 315 |
| Figure 15-103 PWM input mode.....                                                          | 316 |
| Figure 15-104 Channel output stage (channel 1 to 3).....                                   | 316 |
| Figure 15-105 Channel 4 output stage .....                                                 | 316 |
| Figure 15-106 PWM mode A in upcounting mode.....                                           | 317 |
| Figure 15-107 PWM mode B in up/down counting mode .....                                    | 318 |
| Figure 15-108 C1ORAW toggles when counter value matches C1DT value .....                   | 318 |
| Figure 15-109 One-pulse mode.....                                                          | 319 |
| Figure 15-110 Clearing CxORAW (PWM mode B) by EXT input.....                               | 319 |
| Figure 15-111 Complementary output with dead-time insertion.....                           | 320 |
| Figure 15-112 TMR output control .....                                                     | 321 |
| Figure 15-113 Example of TMR brake function.....                                           | 321 |
| Figure 15-114 Example of reset mode .....                                                  | 322 |
| Figure 15-115 Example of suspend mode.....                                                 | 322 |
| Figure 15-116 Example of trigger mode .....                                                | 322 |
| Figure 16-1 Window watchdog block diagram .....                                            | 338 |
| Figure 16-2 Window watchdog timing diagram .....                                           | 338 |
| Figure 17-1 WDT block diagram.....                                                         | 341 |
| Figure 18-1 ERTC block diagram .....                                                       | 343 |
| Figure 19-1 ADC block diagram .....                                                        | 360 |
| Figure 19-2 ADC basic operation process.....                                               | 362 |
| Figure 19-3 ADC power-on and calibration .....                                             | 363 |
| Figure 19-4 Sequence mode .....                                                            | 364 |
| Figure 19-5 Preempted group auto conversion mode.....                                      | 364 |
| Figure 19-6 Repetition mode .....                                                          | 365 |
| Figure 19-7 Partition mode .....                                                           | 365 |
| Figure 19-8 Ordinary oversampling restart mode selection .....                             | 367 |
| Figure 19-9 Ordinary oversampling trigger mode .....                                       | 367 |
| Figure 19-10 Oversampling of preempted group of channels.....                              | 368 |

|                                                                                        |     |
|----------------------------------------------------------------------------------------|-----|
| Figure 19-11 Data alignment .....                                                      | 368 |
| Figure 20-1 Bit timing.....                                                            | 380 |
| Figure 20-2 Frame type .....                                                           | 382 |
| Figure 20-3 Transmit interrupt generation.....                                         | 383 |
| Figure 20-4 Receive interrupt 0 generation.....                                        | 383 |
| Figure 20-5 Receive interrupt 1 generation.....                                        | 383 |
| Figure 20-6 Status error interrupt generation.....                                     | 383 |
| Figure 20-7 CAN block diagram .....                                                    | 384 |
| Figure 20-8 32-bit identifier mask mode.....                                           | 386 |
| Figure 20-9 32-bit identifier list mode .....                                          | 387 |
| Figure 20-10 16-bit identifier mask mode.....                                          | 387 |
| Figure 20-11 16-bit identifier list mode .....                                         | 387 |
| Figure 20-12 Transmit mailbox status .....                                             | 389 |
| Figure 20-13 Receive FIFO status .....                                                 | 390 |
| Figure 20-14 ransmit and receive mailboxes .....                                       | 402 |
| Figure 21-1 OTGFS block diagram .....                                                  | 406 |
| Figure 21-2 OTGHS block diagram.....                                                   | 407 |
| Figure 21-3 OTGFS/HS interrupt hierarchy.....                                          | 409 |
| Figure 21-4 Writing the transmit FIFO .....                                            | 414 |
| Figure 21-5 Reading the receive FIFO .....                                             | 415 |
| Figure 21-6 HFIR behavior when HFIRRLDCTRL=0x0 .....                                   | 416 |
| Figure 21-7 HFIR behavior when HFIRRLDCTRL=0x1 .....                                   | 417 |
| Figure 21-8 Example of common Bulk/Control OUT/SETUP and Bulk/Control IN transfer..... | 420 |
| Figure 21-9 shows an example of common interrupt OUT/IN transfers .....                | 424 |
| Figure 21-10 Example of common isochronous OUT/IN transfers .....                      | 427 |
| Figure 21-11 Read receive FIFO .....                                                   | 432 |
| Figure 21-12 SETUP data packet flowchart .....                                         | 434 |
| Figure 21-13 BULK OUT transfer block diagram .....                                     | 438 |
| Figure 21-14 CSR memory map.....                                                       | 445 |
| Figure 22-1 ACC interrupt mapping diagram.....                                         | 490 |
| Figure 22-2 ACC block diagram .....                                                    | 491 |
| Figure 22-3 Cross-return algorithm .....                                               | 492 |
| Figure 23-1 QSPI block diagram .....                                                   | 496 |
| Figure 23-2 DMA handshake mode.....                                                    | 497 |
| Figure 23-3 Write enable .....                                                         | 498 |
| Figure 23-4 Page programming.....                                                      | 498 |
| Figure 23-5 Status read .....                                                          | 498 |
| Figure 23-6 Data read.....                                                             | 498 |
| Figure 23-7 read dual command .....                                                    | 499 |
| Figure 23-8 Quick read dual-wire I/O command .....                                     | 499 |
| Figure 23-9 Read quad output.....                                                      | 500 |
| Figure 23-10 Quick read quad I/O command .....                                         | 500 |
| Figure 23-11 Dual DPI command .....                                                    | 501 |
| Figure 23-12 Quad QPI command .....                                                    | 501 |
| Figure 24-1 IRTMR block diagram .....                                                  | 511 |

## List of tables

|                                                                                    |     |
|------------------------------------------------------------------------------------|-----|
| Table 1-1 Bit-band address mapping in SRAM .....                                   | 35  |
| Table 1-2 Bit-band address mapping in the peripheral area .....                    | 36  |
| Table 1-3 AT32F402/405 series vector table .....                                   | 36  |
| Table 1-4 List of abbreviations for registers.....                                 | 41  |
| Table 1-5 Base address and reset value of registers .....                          | 42  |
| Table 2-1 Flash memory organization (256 KB).....                                  | 44  |
| Table 2-2 Flash memory organization (128 KB).....                                  | 44  |
| Table 2-3 Peripheral boundary address .....                                        | 45  |
| Table 3-1 PWC register map and reset values.....                                   | 52  |
| Table 4-1 CRM register map and reset values .....                                  | 59  |
| Table 5-1 Flash memory architecture (256 KB).....                                  | 77  |
| Table 5-2 Flash memory architecture (128 KB).....                                  | 77  |
| Table 5-3 User system data area.....                                               | 78  |
| Table 5-4 Flash memory access limit .....                                          | 86  |
| Table 5-5 Flash memory register map and reset value .....                          | 88  |
| Table 6-1 Port A multiplexed function configuration with GPIOA_MUX* register ..... | 100 |
| Table 6-2 Port B multiplexed function configuration with GPIOB_MUX* register ..... | 102 |
| Table 6-3 Port C multiplexed function configuration with GPIOC_MUX* register ..... | 104 |
| Table 6-4 Port D multiplexed function configuration with GPIOD_MUX* register ..... | 106 |
| Table 6-5 Port F multiplexed function configuration with GPIOF_MUX* register ..... | 106 |
| Table 6-6 Pins owned by hardware .....                                             | 107 |
| Table 6-7 GPIO register map and reset values.....                                  | 108 |
| Table 7-1 SCFG register map and reset value .....                                  | 113 |
| Table 8-1 External interrupt/event controller register map and reset value .....   | 119 |
| Table 9-1 DMA error event.....                                                     | 124 |
| Table 9-2 DMA interrupts .....                                                     | 124 |
| Table 9-3 Flexible DMA1 / DMA2 request mapping .....                               | 125 |
| Table 9-4 DMAMUX EXINT LINE for trigger input and synchronized input .....         | 126 |
| Table 9-5 DMA register map and reset value .....                                   | 127 |
| Table 10-1 CRC register map and reset value .....                                  | 139 |
| Table 11-1 I <sup>2</sup> C timing specifications .....                            | 145 |
| Table 11-2 I <sup>2</sup> C configuration.....                                     | 146 |
| Table 11-3 SMBus timeout specification .....                                       | 155 |
| Table 11-4 SMBus timeout detection configuration .....                             | 156 |
| Table 11-5 SMBus mode configuration.....                                           | 156 |
| Table 11-6 I <sup>2</sup> C error events .....                                     | 165 |
| Table 11-7 I <sup>2</sup> C interrupt requests .....                               | 166 |
| Table 11-8 I <sup>2</sup> C register map and reset value .....                     | 166 |
| Table 12-1 Error calculation for programmed baud rate .....                        | 181 |
| Table 12-2 Data sampling over start bit and noise detection .....                  | 184 |
| Table 12-3 Data sampling over valid data and noise detection.....                  | 184 |
| Table 12-4 Maximum allowable deviation.....                                        | 185 |

|                                                                                                     |     |
|-----------------------------------------------------------------------------------------------------|-----|
| Table 12-5 USART interrupt requests.....                                                            | 186 |
| Table 12-6 USART register map and reset value .....                                                 | 186 |
| Table 13-1 Audio frequency precision using system clock.....                                        | 212 |
| Table 13-2 SPI register map and reset value .....                                                   | 215 |
| Table 14-1 I <sup>2</sup> SF5 register map and reset value .....                                    | 225 |
| Table 15-1 TMR functional comparison.....                                                           | 228 |
| Table 15-2 TMR6 and TMR7 register table and reset value .....                                       | 231 |
| Table 15-3 TMRx internal trigger connection.....                                                    | 236 |
| Table 15-4 Counting direction versus encoder signals.....                                           | 239 |
| Table 15-5 TMR2 to TMR4 register map and reset value .....                                          | 248 |
| Table 15-6 Standard CxOUT channel output control bit.....                                           | 257 |
| Table 15-7 TMRx internal trigger connection.....                                                    | 262 |
| Table 15-8 TMR9 register map and reset value .....                                                  | 274 |
| Table 15-9 Complementary output channel CxOUT and CxCOUT control bits with brake function.....      | 282 |
| Table 15-10 TMR10/11/13/14 register map and reset value .....                                       | 296 |
| Table 15-11 Complementary output channel CxOUT and CxCOUT control bits with brake function .....    | 302 |
| Table 15-12 TMRx internal trigger connection.....                                                   | 309 |
| Table 15-13 Counting direction versus encoder signals.....                                          | 313 |
| Table 15-14 TMR1 register map and reset value .....                                                 | 323 |
| Table 15-15 Complementary output channel CxOUT and CxCOUT control bits with brake function .....    | 333 |
| Table 16-1 Minimum and maximum timeout value when PCLK1=72 MHz.....                                 | 338 |
| Table 16-2 WWDT register map and reset value .....                                                  | 339 |
| Table 17-1 WDT timeout period (LICK=40kHz).....                                                     | 341 |
| Table 17-2 WDT register and reset value .....                                                       | 341 |
| Table 18-1 RTC register map and reset values.....                                                   | 344 |
| Table 18-2 ERTC low-power mode wakeup .....                                                         | 349 |
| Table 18-3 Interrupt control bits .....                                                             | 349 |
| Table 18-4 ERTC register map and reset values .....                                                 | 350 |
| Table 19-1 Trigger sources for ordinary channels .....                                              | 363 |
| Table 19-2 Correlation between maximum cumulative data, oversampling multiple and shift digits..... | 366 |
| Table 19-3 ADC register map and reset values.....                                                   | 369 |
| Table 20-1 CAN register map and reset values .....                                                  | 391 |
| Table 21-1 OTGFS input/output pins .....                                                            | 408 |
| Table 21-2 OTGHS input/output pins.....                                                             | 409 |
| Table 21-3 OTGFS/HS transmit FIFO SRAM allocation .....                                             | 411 |
| Table 21-4 OTGFS/HS internal memory storage space allocation .....                                  | 412 |
| Table 21-5 OTGFS/HS register map and reset values .....                                             | 445 |
| Table 21-6 Minimum duration for software disconnect.....                                            | 472 |
| Table 22-1 ACC interrupt requests .....                                                             | 490 |
| Table 22-2 ACC register map and reset values.....                                                   | 493 |
| Table 23-1 QSPI register map and reset values .....                                                 | 503 |
| Table 25-1 DEBUG register address and reset value .....                                             | 512 |

# 1 System architecture

AT32F402/405 series microcontrollers consist of 32-bit ARM® Cortex®-M4F processor, multiple 16-bit and 32-bit timers, infrared transmitter (IRTMR), DMA controller, ERTC, communication interfaces such as SPI, I<sup>2</sup>C and USART/UART, CAN bus controller, USB2.0 OTG full-speed interface, HICK with automatic clock calibration (ACC), 12-bit ADC, programmable voltage monitor (PVM) and other peripherals. Cortex®-M4F processor supports enhanced high-performance DSP instruction set, including extended single-cycle 16-bit/32-bit multiply accumulator (MAC), dual 16-bit MAC instructions, optimized 8-bit/16-bit SIMD operation and saturation operation instructions, and single-precision (IEEE-754) floating point unit (FPU), as shown in Figure 1-1.

Figure 1-1 AT32F402/405 series microcontrollers system architecture



## 1.1 System overview

### 1.1.1 ARM Cortex®-M4F processor

Cortex®-M4F processor is a low-power consumption processor featuring with low gate count, low interrupt latency and low-cost debug. It supports DSP instruction set and FPU, and it is applicable to deeply embedded applications that require quicker response to interruption. Cortex®-M4F processor is based on ARMv7-M architecture, supporting both Thumb instruction set and DSP instruction set.

Figure 1-2 shows the internal block diagram of Cortex®-M4F processor. Please refer to *ARM®Cortex-M4 Technical Reference Manual* for more information.

Figure 1-2 Internal block diagram of Cortex®-M4F



### 1.1.2 Bit band

With the help of bit-band, read and write access to a single bit can be performed using common load/store operations. The Cortex®-M4F memory includes two bit-band regions: the least significant 1 Mbyte of SRAM and the least significant 1 Mbyte of peripherals. In addition to access to bit-band addresses, their respective bit-band alias region can be used to access to any bit in these two bit-band regions. The bit-band alias region transforms each bit into 32-bit word. Thus, accessing to a bit in an alias region has the same effect as read-modify-write operation on the corresponding bit in a bit-band region.

Figure 1-3 Comparison between bit-band region and its alias region: image A



Figure 1-4 Comparison between bit-band region and its alias region: image B



Bit-band region: address region for bit-band operations

Bit-band alias region: access to the alias region has the same effect as read-modify-write operation on the bit-band region

Each bit in a bit-band region is mapped into a word (LSB) in an alias region. When accessing to the address in a bit-band alias region, such address is transformed into a bit-band address first. For a read operation, read one word in the bit-band region, and then move the targeted bit to the right to LSB before returning LSB. For a write operation, first move the targeted bit to the left to the corresponding bit number, then perform a read-modify-write operation on bit level.

The address ranges of two memories supporting bit-band operations:

Least significant 1 Mbyte in SRAM: 0x2000\_0000~0x200F\_FFFF

Least significant 1 Mbyte in peripherals: 0x4000\_0000~0x400F\_FFFF

For a bit in the SRAM bit-band region, if the byte address is A, the bit number is n (0<=n<=7), then the alias address where the bit is:

$$\text{AliasAddr} = 0x2200\_0000 + (A - 0x2000\_0000) * 32 + n * 4$$

For a bit in the peripheral bit-band region, if the byte address is A, the bit number is n (0<=n<=7), then the alias address where the bit is:

$$\text{AliasAddr} = 0x4200\_0000 + (A - 0x4000\_0000) * 32 + n * 4$$

Table 1-1 shows the mapping between bit-band region and alias region in SRAM.

Table 1-1 Bit-band address mapping in SRAM

| Bit-band region | Equivalent alias address |
|-----------------|--------------------------|
| 0x2000_0000.0   | 0x2200_0000.0            |
| 0x2000_0000.1   | 0x2200_0004.0            |
| 0x2000_0000.2   | 0x2200_0008.0            |
| ...             | ...                      |
| 0x2000_0000.31  | 0x2200_007C.0            |
| 0x2000_0004.0   | 0x2200_0080.0            |
| 0x2000_0004.1   | 0x2200_0084.0            |

|                |               |
|----------------|---------------|
| 0x2000_0004.2  | 0x2200_0088.0 |
| ...            | ...           |
| 0x200F_FFFC.31 | 0x23FF_FFFC.0 |

Table 1-2 shows the mapping between bit-band region and alias region in the peripheral area.

Table 1-2 Bit-band address mapping in the peripheral area

| Bit-band region | Equivalent alias address |
|-----------------|--------------------------|
| 0x4000_0000.0   | 0x4200_0000.0            |
| 0x4000_0000.1   | 0x4200_0004.0            |
| 0x4000_0000.2   | 0x4200_0008.0            |
| ...             | ...                      |
| 0x4000_0000.31  | 0x4200_007C.0            |
| 0x4000_0004.0   | 0x4200_0080.0            |
| 0x4000_0004.1   | 0x4200_0084.0            |
| 0x4000_0004.2   | 0x4200_0088.0            |
| ...             | ...                      |
| 0x400F_FFFC.31  | 0x43FF_FFFC.0            |

In terms of bit-band operation, one of the advantages is to control LED ON/OFF independently via GPIO pins. On the other hand, it brings great convenience for serial interface operations. In short, it is best suited to hardware I/O-intensive low-level applications.

In addition, bit-band operations can also simplify jump process. When jump operation is based on a bit level, the previous steps are:

- Read the whole register
- Mask the undesired bits
- Compare and jump

For now, you just need to:

- Read the bit status from the bit-band alias region
- Compare and jump

Apart from making code more concise, its important function is also reflected in multi-task environment. When it comes to multiple tasks, it turns the read-modify-write operations into a hardware-supported atomic operation to avoid the scenario where the read-modify-write operation is disrupted, resulting in disorder.

### 1.1.3 Interrupt and exception vectors

Table 1-3 AT32F402/405 series vector table

| Pos. | Priority     | Priority type | Name                                                                                                   | Description | Address     |
|------|--------------|---------------|--------------------------------------------------------------------------------------------------------|-------------|-------------|
| -    | -            | -             | Reserved                                                                                               |             | 0x0000_0000 |
| -3   | Fixed        | Reset         | Reset                                                                                                  |             | 0x0000_0004 |
| -2   | Fixed        | NMI           | Non-maskable interrupt<br>CRM clock fail detector (CFD) and SRAM verification are linked to NMI vector |             | 0x0000_0008 |
| -1   | Fixed        | HardFault     | All class of fault                                                                                     |             | 0x0000_000C |
| 0    | Configurable | MemoryManage  | Memory management                                                                                      |             | 0x0000_0010 |
| 1    | Configurable | BusFault      | Pre-fetch fault, memory access fault                                                                   |             | 0x0000_0014 |

|    |              |              |                                         |                                                            |             |
|----|--------------|--------------|-----------------------------------------|------------------------------------------------------------|-------------|
| 2  | Configurable | UsageFault   | Undefined instruction or illegal state  | 0x0000_0018                                                |             |
| -  | -            | -            | Reserved                                | 0x0000_001C<br>~0x0000_002B                                |             |
| 3  | Configurable | SVCall       | System service call via SWI instruction | 0x0000_002C                                                |             |
| 4  | Configurable | DebugMonitor | Debug monitor                           | 0x0000_0030                                                |             |
| -  | -            | -            | Reserved                                | 0x0000_0034                                                |             |
| 5  | Configurable | PendSV       | Pendable request for system service     | 0x0000_0038                                                |             |
| 6  | Configurable | SysTick      | System tick timer                       | 0x0000_003C                                                |             |
| 0  | 7            | Configurable | WWDT                                    | Window watchdog timer                                      | 0x0000_0040 |
| 1  | 8            | Configurable | PVM                                     | PVM from EXINT interrupt                                   | 0x0000_0044 |
| 2  | 9            | Configurable | TAMPER                                  | Tamper interrupt                                           | 0x0000_0048 |
| 3  | 10           | Configurable | ERTC_WKUP                               | ERTC wakeup interrupt                                      | 0x0000_004C |
| 4  | 11           | Configurable | FLASH                                   | Flash global interrupt                                     | 0x0000_0050 |
| 5  | 12           | Configurable | CRM                                     | Clock and Reset Manage (CRM) interrupt                     | 0x0000_0054 |
| 6  | 13           | Configurable | EXINT0                                  | EXINT line0 interrupt                                      | 0x0000_0058 |
| 7  | 14           | Configurable | EXINT1                                  | EXINT line1 interrupt                                      | 0x0000_005C |
| 8  | 15           | Configurable | EXINT2                                  | EXINT line2 interrupt                                      | 0x0000_0060 |
| 9  | 16           | Configurable | EXINT3                                  | EXINT line3 interrupt                                      | 0x0000_0064 |
| 10 | 17           | Configurable | EXINT4                                  | EXINT line4 interrupt                                      | 0x0000_0068 |
| 11 | 18           | Configurable | DMA1 channel1                           | DMA1 channel1 global interrupt                             | 0x0000_006C |
| 12 | 19           | Configurable | DMA1 channel2                           | DMA1 channel2 global interrupt                             | 0x0000_0070 |
| 13 | 20           | Configurable | DMA1 channel3                           | DMA1 channel3 global interrupt                             | 0x0000_0074 |
| 14 | 21           | Configurable | DMA1 channel4                           | DMA1 channel4 global interrupt                             | 0x0000_0078 |
| 15 | 22           | Configurable | DMA1 channel5                           | DMA1 channel5 global interrupt                             | 0x0000_007C |
| 16 | 23           | Configurable | DMA1 channel6                           | DMA1 channel6 global interrupt                             | 0x0000_0080 |
| 17 | 24           | Configurable | DMA1 channel7                           | DMA1 channel7 global interrupt                             | 0x0000_0084 |
| 18 | 25           | Configurable | ADC                                     | ADC global interrupt                                       | 0x0000_0088 |
| 19 | 26           | Configurable | CAN1_TX                                 | CAN1 TX interrupt                                          | 0x0000_008C |
| 20 | 27           | Configurable | CAN1_RX0                                | CAN1 RX0 interrupt                                         | 0x0000_0090 |
| 21 | 28           | Configurable | CAN1_RX1                                | CAN1 RX1 interrupt                                         | 0x0000_0094 |
| 22 | 29           | Configurable | CAN_SE                                  | CAN state error interrupt                                  | 0x0000_0098 |
| 23 | 30           | Configurable | EXINT9_5                                | EXINT line[9:5] interrupt                                  | 0x0000_009C |
| 24 | 31           | Configurable | TMR1_BRK_TMR9                           | TMR1 brake interrupt and TMR9 global interrupt             | 0x0000_00A0 |
| 25 | 32           | Configurable | TMR1_OVF_TMR10                          | TMR1 overflow interrupt and TMR10 global interrupt         | 0x0000_00A4 |
| 26 | 33           | Configurable | TMR1_TRG_HALL_TMR11                     | TMR1 trigger and HALL interrupt and TMR11 global interrupt | 0x0000_00A8 |
| 27 | 34           | Configurable | TMR1_CH                                 | TMR1 channel interrupt                                     | 0x0000_00AC |

|    |    |              |               |                                                 |             |
|----|----|--------------|---------------|-------------------------------------------------|-------------|
| 28 | 35 | Configurable | TMR2          | TMR2 global interrupt                           | 0x0000_00B0 |
| 29 | 36 | Configurable | TMR3          | TMR3 global interrupt                           | 0x0000_00B4 |
| 30 | 37 | Configurable | TMR4          | TMR4 global interrupt                           | 0x0000_00B8 |
| 31 | 38 | Configurable | I2C1_EVT      | I <sup>2</sup> C1 event interrupt               | 0x0000_00BC |
| 32 | 39 | Configurable | I2C1_ERR      | I <sup>2</sup> C1 error interrupt               | 0x0000_00C0 |
| 33 | 40 | Configurable | I2C2_EVT      | I <sup>2</sup> C2 event interrupt               | 0x0000_00C4 |
| 34 | 41 | Configurable | I2C2_ERR      | I <sup>2</sup> C2 error interrupt               | 0x0000_00C8 |
| 35 | 42 | Configurable | SPI1          | SPI1 global interrupt                           | 0x0000_00CC |
| 36 | 43 | Configurable | SPI2          | SPI2 global interrupt                           | 0x0000_00D0 |
| 37 | 44 | Configurable | USART1        | USART1 global interrupt                         | 0x0000_00D4 |
| 38 | 45 | Configurable | USART2        | USART2 global interrupt                         | 0x0000_00D8 |
| 39 | 46 | Configurable | USART3        | USART3 global interrupt                         | 0x0000_00DC |
| 40 | 47 | Configurable | EXINT15_10    | EXINT line[15:10] interrupt                     | 0x0000_00E0 |
| 41 | 48 | Configurable | ERTCAlarm     | ERTC alarm interrupt linked to EXINT            | 0x0000_00E4 |
| 42 | 49 | Configurable | OTGFS1_WKUP   | OTGFS1 standby wakeup interrupt linked to EXINT | 0x0000_00E8 |
| 43 | 50 | -            | -             | -                                               | 0x0000_00EC |
| 44 | 51 | Configurable | TMR13         | TMR13 global interrupt                          | 0x0000_00F0 |
| 45 | 52 | Configurable | TMR14         | TMR14 global interrupt                          | 0x0000_00F4 |
| 46 | 53 | -            | -             | -                                               | 0x0000_00F8 |
| 47 | 54 | -            | -             | -                                               | 0x0000_00FC |
| 48 | 55 | -            | -             | -                                               | 0x0000_0100 |
| 49 | 56 | -            | -             | -                                               | 0x0000_0104 |
| 50 | 57 | -            | -             | -                                               | 0x0000_0108 |
| 51 | 58 | Configurable | SPI3          | SPI3 global interrupt                           | 0x0000_010C |
| 52 | 59 | Configurable | USART4        | USART4 global interrupt                         | 0x0000_0110 |
| 53 | 60 | Configurable | USART5        | USART5 global interrupt                         | 0x0000_0114 |
| 54 | 61 | Configurable | TMR6          | TMR6 global interrupt                           | 0x0000_0118 |
| 55 | 62 | Configurable | TMR7          | TMR7 global interrupt                           | 0x0000_011C |
| 56 | 63 | Configurable | DMA2 channel1 | DMA2 channel1 global interrupt                  | 0x0000_0120 |
| 57 | 64 | Configurable | DMA2 channel2 | DMA2 channel2 global interrupt                  | 0x0000_0124 |
| 58 | 65 | Configurable | DMA2 channel3 | DMA2 channel3 global interrupt                  | 0x0000_0128 |
| 59 | 66 | Configurable | DMA2 channel4 | DMA2 channel4 global interrupt                  | 0x0000_012C |
| 60 | 67 | Configurable | DMA2 channel5 | DMA2 channel5 global interrupt                  | 0x0000_0130 |
| 61 | 68 | -            | -             | -                                               | 0x0000_0134 |
| 62 | 69 | -            | -             | -                                               | 0x0000_0138 |

|    |     |              |               |                                                |              |
|----|-----|--------------|---------------|------------------------------------------------|--------------|
| 63 | 70  | -            | -             | -                                              | 0x0000_013C  |
| 64 | 71  | -            | -             | -                                              | 0x0000_0140  |
| 65 | 72  | -            | -             | -                                              | 0x0000_0144  |
| 66 | 73  | -            | -             | -                                              | 0x0000_0148  |
| 67 | 74  | Configurable | OTGFS1        | OTGFS1 global interrupt                        | 0x0000_014C  |
| 68 | 75  | Configurable | DMA2 channel6 | DMA2 channel6 global interrupt                 | 0x0000_0150  |
| 69 | 76  | Configurable | DMA2 channel7 | DMA2 channel7 global interrupt                 | 0x0000_0154  |
| 70 | 77  | -            | -             | -                                              | 0x0000_0158  |
| 71 | 78  | Configurable | USART6        | USART6 global interrupt                        | 0x0000_015C  |
| 72 | 79  | Configurable | I2C3_EVT      | I <sup>2</sup> C3 event interrupt              | 0x0000_0160  |
| 73 | 80  | Configurable | I2C3_ERR      | I <sup>2</sup> C3 error interrupt              | 0x0000_0164  |
| 74 | 81  | Configurable | OTGHS_EP1_OUT | OTGHS EP1 OUT interrupt                        | 0x0000_0168  |
| 75 | 82  | Configurable | OTGHS_EP1_IN  | OTGHS EP1 IN interrupt                         | 0x0000_016C  |
| 76 | 83  | Configurable | OTGHS_WKUP    | OTGHS standby wakeup interrupt linked to EXINT | 0x0000_0170  |
| 77 | 84  | Configurable | OTGHS         | OTGHS global interrupt                         | 0x0000_0174  |
| 78 | 85  | -            | -             | -                                              | 0x0000_0178  |
| 79 | 86  | -            | -             | -                                              | 0x0-000_017C |
| 80 | 87  | -            | -             | -                                              | 0x0000_0180  |
| 81 | 88  | Configurable | FPU           | FPU exception interrupt                        | 0x0000_0184  |
| 82 | 89  | Configurable | UART7         | UART7 global interrupt                         | 0x0000_0188  |
| 83 | 90  | Configurable | UART8         | UART8 global interrupt                         | 0x0000_018C  |
| 84 | 91  | -            | -             | -                                              | 0x0000_0190  |
| 85 | 92  | Configurable | I2SF5         | I <sup>2</sup> SF5 global interrupt            | 0x0000_0194  |
| 86 | 93  | -            | -             | -                                              | 0x0000_0198  |
| 87 | 94  | -            | -             | -                                              | 0x0000_019C  |
| 88 | 95  | -            | -             | -                                              | 0x0000_01A0  |
| 89 | 96  | -            | -             | -                                              | 0x0000_01A4  |
| 90 | 97  | -            | -             | -                                              | 0x0000_01A8  |
| 91 | 98  | -            | -             | -                                              | 0x0000_01AC  |
| 92 | 99  | Configurable | QSPI1         | QSPI1 global interrupt                         | 0x0000_01B0  |
| 93 | 100 | -            | -             | -                                              | 0x0000_01B4  |
| 94 | 101 | Configurable | DMAMUX        | DMAMUX overflow interrupt                      | 0x0000_01B8  |
| 95 | 102 | -            | -             | -                                              | 0x0000_01BC  |
| 96 | 103 | -            | -             | -                                              | 0x0000_01C0  |
| 97 | 104 | -            | -             | -                                              | 0x0000_01C4  |

|     |     |              |     |                      |             |
|-----|-----|--------------|-----|----------------------|-------------|
| 98  | 105 | -            | -   | -                    | 0x0000_01C8 |
| 99  | 106 | -            | -   | -                    | 0x0000_01CC |
| 100 | 107 | -            | -   | -                    | 0x0000_01D0 |
| 101 | 108 | -            | -   | -                    | 0x0000_01D4 |
| 102 | 109 | -            | -   | -                    | 0x0000_01D8 |
| 103 | 110 | Configurable | ACC | ACC global interrupt | 0x0000_01DC |

## 1.1.4 System Tick (SysTick)

The System Tick is a 24-bit downcounter. It will be reloaded with the initial value automatically when it is decremented to zero. It can generate periodic interrupts, so it is often used as multi-task scheduling counter for embedded operating system, and also to call the periodic tasks for non-embedded system. The System Tick calibration value is fixed to 9000, which gives a reference time base of 1 ms when the System Tick clock is set to 9 MHz.

## 1.1.5 Reset

The processor reads the first two words from the CODE memory after a system reset and before program execution.

- Get the initial value of the main stack pointer (MSP) from address 0x0000\_0000.

Get the initial value of the program counter (PC) from address 0x0000\_0004. This value is a reset vector and LSB must be 1. Then, take the instructions from the address corresponding to this value.

Figure 1-5 Reset process



Cortex®-M4F uses a full stack that increases downward, so the initial value of the main stack pointer (MSP) must be the end address of the stack memory plus 1. For example, if the stack area is set between 0x2000\_7C00 and 0x2000\_7FFF, then the initial value of MSP must be defined as 0x2000\_8000.

The vector table follows the initial value of MSP. Cortex®-M4F operates in Thumb state, and thus each value in the vector table must set the LSB to 1. In Figure 1-6, 0x0000\_0101 is used to represent 0x0000\_0100. After the instruction at 0x0000\_0100 is executed, the program starts running formally. Before that, it is a must for initializing MSP, because the first instruction may be interrupted by NMI or other faults before being executed. After the completion of MSP initialization, it is ready to prepare stack room for its service routines.

Figure 1-6 Example of MSP and PC initialization



In the AT32F402/405 series, the main Flash memory, boot memory or SRAM can be remapped to the CODE area between 0x0000\_0000 and 0x07FF\_FFFF. The nBOOT1 corresponds to the value of system setting byte (SSB) bit of the user system data area (USD). The nBOOT1 and BOOT0 are used to set the specific memory from which CODE starts.

{nBOOT1, BOOT0}=00/10: CODE starts from the main Flash memory.

{nBOOT1, BOOT0}=11: CODE starts from the boot memory.

{nBOOT1, BOOT0}=01: CODE starts from SRAM.

After a system reset or when leaving from Standby mode, the pin values of both nBOOT1 and BOOT0 will be relatched.

If on-chip SRAM mode is used, the BOOT state is locked. In this case, it is impossible to select another boot mode, even after a system reset. A new boot mode can be selected only after the next power-on reset.

Boot memory contains an embedded Bootloader program that provides not only Flash programming function through USART, I<sup>2</sup>C, SPI, CAN or USB interface, but also provides extra firmware including communication protocol stacks that can be called for use by software developers through API.

## 1.2 List of abbreviations for registers

Table 1-4 List of abbreviations for registers

| Register type | Description                                                                                |
|---------------|--------------------------------------------------------------------------------------------|
| rw            | Software can read and write to this bit.                                                   |
| ro            | Software can only read this bit.                                                           |
| wo            | Software can only write to this bit. Reading it returns to its reset value.                |
| rrc           | Software can read this bit. Reading this bit automatically clears it.                      |
| rw0c          | Software can read this bit and clear it by writing 0. Writing 1 has no effect on this bit. |
| rw1c          | Software can read this bit and clear it by writing 1. Writing 0 has no effect on this bit. |
| rw1s          | Software can read this bit and set it by writing 1. Writing 0 has no effect on this bit.   |

|      |                                                                                             |
|------|---------------------------------------------------------------------------------------------|
| tog  | Software can read this bit and toggle it by writing 1. Writing 0 has no effect on this bit. |
| rwt  | Software can read this bit. Writing any value will trigger an event.                        |
| resd | Reserved                                                                                    |

## 1.3 Device characteristics information

Table 1-5 Base address and reset value of registers

| Register abbr. | Base address | Reset value |
|----------------|--------------|-------------|
| F_SIZE         | 0x1FFF F7E0  | 0xFFFF      |
| UID[31:0]      | 0x1FFF F7E8  | 0xFFFF XXXX |
| UID[63:32]     | 0x1FFF F7EC  | 0xFFFF XXXX |
| UID[95:64]     | 0x1FFF F7F0  | 0xFFFF XXXX |

### 1.3.1 Flash memory size register

This register contains the information about Flash memory size.

| Bit      | Abbr.  | Reset value | Type | Description                                                      |
|----------|--------|-------------|------|------------------------------------------------------------------|
| Bit 15:0 | F_SIZE | 0xFFFF      | ro   | Flash size, in terms of Kbyte<br>For example, 0x0040 = 64 Kbytes |

### 1.3.2 Device electronic signature

The device electronic signature contains the memory size and the unique device ID (96 bits). It is stored in the information block of the Flash memory. The 96-bit ID is unique for any device, and cannot be altered by users. It can be used for the following:

- Serial number, such as USB string serial number
- Part of security keys

| Bit      | Abbr.     | Reset value | Type | Description           |
|----------|-----------|-------------|------|-----------------------|
| Bit 31:0 | UID[31:0] | 0xFFFF XXXX | ro   | UID for bit31 to bit0 |

| Bit      | Abbr.      | Reset value | Type | Description            |
|----------|------------|-------------|------|------------------------|
| Bit 31:0 | UID[63:32] | 0xFFFF XXXX | ro   | UID for bit63 to bit32 |

| Bit      | Abbr.      | Reset value | Type | Description            |
|----------|------------|-------------|------|------------------------|
| Bit 31:0 | UID[95:64] | 0xFFFF XXXX | ro   | UID for bit95 to bit64 |

Note: UID[95:88] is Series ID, which is 0x13h for AT32F405 and 0x14h for AT32F402.

## 2 Memory resources

### 2.1 Internal memory address map

Internal memory contains program memory (Flash), data memory (SRAM), peripheral registers and core registers. Their respective address mapping are shown in Figure 2-1.

Figure 2-1 AT32F402/405 address mapping



## 2.2 Flash memory

AT32F402/405 series provide up to 256 KB of on-chip Flash memory, supporting a single-cycle 32-bit read operation.

Refer to Chapter 5 for more details about Flash memory controller and register configuration.

### Flash memory organization (256 KB)

The main memory contains bank 1 (256 Kbytes), including 128 sectors, 2 Kbytes per sector.

Table 2-1 Flash memory organization (256 KB)

| Bank                  | Name              | Address range             |                           |
|-----------------------|-------------------|---------------------------|---------------------------|
| Main memory<br>256 KB | Sector 0          | 0x0800 0000 – 0x0800 07FF |                           |
|                       | Sector 1          | 0x0800 0800 – 0x0800 0FFF |                           |
|                       | Sector 2          | 0x0800 1000 – 0x0800 17FF |                           |
|                       | Sector 3          | 0x0800 1800 – 0x0800 1FFF |                           |
|                       | Sector 4          | 0x0800 2000 – 0x0800 27FF |                           |
|                       | .                 | .                         |                           |
|                       | Sector 127        | 0x0803 F800 – 0x0803 FFFF |                           |
|                       | Information block | 20 KB bootloader          | 0x1FFF A400 – 0x1FFF F3FF |
|                       |                   | 512 B user system data    | 0x1FFF F800 – 0x1FFF F9FF |

### Flash memory organization (128 KB)

The main memory contains bank 1 (128 Kbytes), including 128 sectors, 1 Kbyte per sector.

Table 2-2 Flash memory organization (128 KB)

| Bank                  | Name              | Address range             |                           |
|-----------------------|-------------------|---------------------------|---------------------------|
| Main memory<br>128 KB | Sector 0          | 0x0800 0000 – 0x0800 03FF |                           |
|                       | Sector 1          | 0x0800 0400 – 0x0800 07FF |                           |
|                       | Sector 2          | 0x0800 0800 – 0x0800 0BFF |                           |
|                       | Sector 3          | 0x0800 0C00 – 0x0800 0FFF |                           |
|                       | Sector 4          | 0x0800 1000 – 0x0800 13FF |                           |
|                       | .                 | .                         |                           |
|                       | Sector 127        | 0x0801 FC00 – 0x0801 FFFF |                           |
|                       | Information block | 20 KB bootloader          | 0x1FFF A400 – 0x1FFF F3FF |
|                       |                   | 512 B user system data    | 0x1FFF F800 – 0x1FFF F9FF |

## 2.3 SRAM memory

The AT32F402/405 series contain a 102-KB on-chip SRAM that starts at the address of 0x2000\_0000. It can be accessed by bytes, half-words (16-bit) or words (32-bit).

The odd parity checking of SRAM can be enabled or disabled by setting the nRAM\_PRT\_CHK bit in the Flash user data system area. Once enabled, the maximum SRAM size available is only 96KB, with the remaining 6KB used to store odd parity checking result.

In addition, when data are written to SRAM, odd parity check is automatically calculated on a 1-KB unit level by hardware which will then store the generated 1-bit odd parity check bit into SRAM. When reading, the hardware will automatically check the integrity of the result, set NMI bit if an error occurs, and report the error state to the bit 8 in the SCFG\_CFG2 register. Enabling the SRAM\_OPERR\_LK bit can allow the SRAM odd parity check error state to be connected to the brake input of TMR1/TMR9/10/11/13/14.

Note: SRAM odd parity check applies to the first 48KB of the SRAM only. To enable SRAM odd parity check, it is necessary to initialize the whole SRAM to prevent the occurrence of odd parity check error.

## 2.4 Peripheral address map

Table 2-3 Peripheral boundary address

| Bus | Boundary address          | Peripherals                    |
|-----|---------------------------|--------------------------------|
| AHB | 0xC000 0000 - 0xFFFF FFFF | Reserved                       |
|     | 0xA000 1400 - 0xBFFF FFFF | Reserved                       |
|     | 0xA000 1000 - 0xA000 13FF | QSPI Register                  |
|     | 0xA000 0000 - 0xA000 0FFF | Reserved                       |
|     | 0x9000 0000 - 0x9FFF FFFF | QSPI1                          |
|     | 0x6000 0000 - 0x8FFF FFFF | Reserved                       |
|     | 0x5004 0000 - 0x5FFF FFFF | Reserved                       |
|     | 0x5000 0000 - 0x5003 FFFF | OTG_FS1                        |
|     | 0x4008 0000 - 0x4FFF FFFF | Reserved                       |
|     | 0x4004 0000 - 0x4007 FFFF | OTG_HS                         |
|     | 0x4002 6800 - 0x4003 FFFF | Reserved                       |
|     | 0x4002 6400 - 0x4002 67FF | DMA2                           |
|     | 0x4002 6000 - 0x4002 63FF | DMA1                           |
|     | 0x4002 4000 - 0x4002 5FFF | Reserved                       |
|     | 0x4002 3C00 - 0x4002 3FFF | Flash memory interface (FLASH) |
|     | 0x4002 3800 - 0x4002 3BFF | Clock and reset manage (CRM)   |
|     | 0x4002 3400 - 0x4002 37FF | Reserved                       |
|     | 0x4002 3000 - 0x4002 33FF | CRC                            |
|     | 0x4002 2000 - 0x4002 2FFF | Reserved                       |
|     | 0x4002 1C00 - 0x4002 1FFF | Reserved                       |
|     | 0x4002 1800 - 0x4002 1BFF | Reserved                       |
|     | 0x4002 1400 - 0x4002 17FF | GPIO port F                    |
|     | 0x4002 1000 - 0x4002 13FF | Reserved                       |
|     | 0x4002 0C00 - 0x4002 0FFF | GPIO port D                    |
|     | 0x4002 0800 - 0x4002 0BFF | GPIO port C                    |
|     | 0x4002 0400 - 0x4002 07FF | GPIO port B                    |
|     | 0x4002 0000 - 0x4002 03FF | GPIO port A                    |

|      |                           |                     |
|------|---------------------------|---------------------|
| APB2 | 0x4001 8000 - 0x4001 FFFF | Reserved            |
|      | 0x4001 7C00 - 0x4001 7FFF | Reserved            |
|      | 0x4001 7800 - 0x4001 7BFF | Reserved            |
|      | 0x4001 7400 - 0x4001 77FF | ACC                 |
|      | 0x4001 7000 - 0x4001 73FF | Reserved            |
|      | 0x4001 6C00 - 0x4001 6FFF | Reserved            |
|      | 0x4001 6800 - 0x4001 6BFF | Reserved            |
|      | 0x4001 6400 - 0x4001 67FF | Reserved            |
|      | 0x4001 6000 - 0x4001 63FF | I <sup>2</sup> SF5  |
|      | 0x4001 5C00 - 0x4001 5FFF | Reserved            |
|      | 0x4001 5800 - 0x4001 5BFF | Reserved            |
|      | 0x4001 5400 - 0x4001 57FF | Reserved            |
|      | 0x4001 5000 - 0x4001 53FF | I <sup>2</sup> SF5  |
|      | 0x4001 4C00 - 0x4001 4FFF | Reserved            |
|      | 0x4001 4800 - 0x4001 4BFF | TMR11 timer         |
|      | 0x4001 4400 - 0x4001 47FF | TMR10 timer         |
|      | 0x4001 4000 - 0x4001 43FF | TMR9 timer          |
|      | 0x4001 3C00 - 0x4001 3FFF | EXINT               |
|      | 0x4001 3800 - 0x4001 3BFF | SCFG                |
|      | 0x4001 3400 - 0x4001 37FF | Reserved            |
|      | 0x4001 3000 - 0x4001 33FF | SPI1/I2S1           |
|      | 0x4001 2C00 - 0x4001 2FFF | Reserved            |
|      | 0x4001 2800 - 0x4001 2BFF | Reserved            |
|      | 0x4001 2400 - 0x4001 27FF | Reserved            |
|      | 0x4001 2000 - 0x4001 23FF | ADC1                |
|      | 0x4001 1C00 - 0x4001 1FFF | Reserved            |
|      | 0x4001 1800 - 0x4001 1BFF | Reserved            |
|      | 0x4001 1400 - 0x4001 17FF | USART6              |
|      | 0x4001 1000 - 0x4001 13FF | USART1              |
|      | 0x4001 0C00 - 0x4001 0FFF | Reserved            |
|      | 0x4001 0800 - 0x4001 0BFF | Reserved            |
|      | 0x4001 0400 - 0x4001 07FF | Reserved            |
|      | 0x4001 0000 - 0x4001 03FF | TMR1 timer          |
| APB1 | 0x4000 8000 - 0x4000 FFFF | Reserved            |
|      | 0x4000 7C00 - 0x4000 7FFF | UART8               |
|      | 0x4000 7800 - 0x4000 7BFF | UART7               |
|      | 0x4000 7400 - 0x4000 77FF | Reserved            |
|      | 0x4000 7000 - 0x4000 73FF | Power control (PWC) |
|      | 0x4000 6C00 - 0x4000 6FFF | Reserved            |
|      | 0x4000 6800 - 0x4000 6BFF | Reserved            |
|      | 0x4000 6400 - 0x4000 67FF | CAN1                |

|                           |                              |
|---------------------------|------------------------------|
| 0x4000 6000 - 0x4000 63FF | Reserved                     |
| 0x4000 5C00 - 0x4000 5FFF | I <sup>2</sup> C3            |
| 0x4000 5800 - 0x4000 5BFF | I <sup>2</sup> C2            |
| 0x4000 5400 - 0x4000 57FF | I <sup>2</sup> C1            |
| 0x4000 5000 - 0x4000 53FF | USART5                       |
| 0x4000 4C00 - 0x4000 4FFF | USART4                       |
| 0x4000 4800 - 0x4000 4BFF | USART3                       |
| 0x4000 4400 - 0x4000 47FF | USART2                       |
| 0x4000 4000 - 0x4000 43FF | Reserved                     |
| 0x4000 3C00 - 0x4000 3FFF | SPI3/I <sup>2</sup> S3       |
| 0x4000 3800 - 0x4000 3BFF | SPI2/I <sup>2</sup> S2       |
| 0x4000 3400 - 0x4000 37FF | Reserved                     |
| 0x4000 3000 - 0x4000 33FF | Watchdog timer (WDT)         |
| 0x4000 2C00 - 0x4000 2FFF | Window watchdog timer (WWDT) |
| 0x4000 2800 - 0x4000 2BFF | ERTC                         |
| 0x4000 2400 - 0x4000 27FF | Reserved                     |
| 0x4000 2000 - 0x4000 23FF | TMR14 timer                  |
| 0x4000 1C00 - 0x4000 1FFF | TMR13 timer                  |
| 0x4000 1800 - 0x4000 1BFF | Reserved                     |
| 0x4000 1400 - 0x4000 17FF | TMR7 timer                   |
| 0x4000 1000 - 0x4000 13FF | TMR6 timer                   |
| 0x4000 0C00 - 0x4000 0FFF | Reserved                     |
| 0x4000 0800 - 0x4000 0BFF | TMR4 timer                   |
| 0x4000 0400 - 0x4000 07FF | TMR3 timer                   |
| 0x4000 0000 - 0x4000 03FF | TMR2 timer                   |

## 3 Power control (PWC)

### 3.1 Introduction

For AT32F402/405 series, the operating voltage supply is 2.4 V ~ 3.6 V, with an operating temperature range of -40~+105 °C. To reduce power consumption, this series provides three types of power saving modes, including Sleep, Deepsleep and Standby modes so as to achieve the best tradeoff among the conflicting demands of CPU operating time, speed and power consumption. The AT32F402/405 series have two power domains, including VDD/VDDA domain and 1.2 V domain. The VDD/VDDA domain is supplied directly by external power, and the 1.2 V domain is powered by an embedded LDO in the VDD/VDDA domain.

Figure 3-1 Block diagram of each power supply



### 3.2 Main features

- Two power domains: VDD/VDDA domain and 1.2 V domain
- Three types of power saving modes: Sleep mode, Deepsleep mode and Standby mode
- Internal voltage regulator supplies 1.2 V voltage source for the core domain
- Power voltage detector is provided to issue an interrupt or event when the supply voltage is lower or higher than the programmed threshold
- VDD/VDDA applies separated digital and analog module to reduce noise on external power

### 3.3 POR/LVR

A POR analog module embedded in the VDD/VDDA domain is used to generate a power reset. The power reset signal is released at  $V_{POR}$  when the VDD is increased from 0 V to the operating voltage, or it is triggered at  $V_{LVR}$  when the VDD drops from the operating voltage to 0 V. During the power-on reset period, the reset signal has certain amount of time delay compared to VDD boost process. At the same time, hysteresis occurs in power-on reset (POR) and low voltage reset (LVR).

Figure 3-2 Power-on/Low voltage reset waveform



### 3.4 Power voltage monitor (PVM)

The PVM is used to monitor the power supply variations. It is enabled by setting the PVMEN bit in the power control register (PWC\_CTRL), and the threshold value for voltage monitor is selected with the PVMSEL[2:0].

After PVM is enabled, the comparison result between VDD and the programmed threshold is indicated by the PVMOF bit in the PWC\_CTRLSTS register, with the hysteresis voltage VHYS\_P being 100 mV. The PVM interrupt will be generated through EXINT line 16 when VDD rises above the PVM threshold.

Figure 3-3 PVM threshold and output



## 3.5 Power domain

### 1.2 V domain

The 1.2 V core domain includes a CPU core, SRAM, embedded digital peripherals and Phase Locked Loop (PLL). Such power domain is supplied by LDO (voltage regulator).

#### VDD/VDDA domain

VDD/VDDA domain includes VDD domain and VDDA domain. The VDD domain contains I/O circuit, power-saving mode wakeup circuit, watchdog timer (WDT), power-on reset/low voltage reset (POR/LVR), LDO, RTC circuit, LEXT and all PAD circuits. The VDDA domain contains ADC (AD converter), temperature sensor and so on.

Typically, to ensure a better accuracy of ADC at a low voltage, the digital circuit is supplied by VDD while the analog circuit is supplied by VDDA. On 64-pin packages and packages with less pins, the external reference voltage VREF+ and VREF- are connected to VDDA pin and VSSA pin, respectively.

In Run Mode, the LDO supplies full power to the 1.2 V core domain and outputs 1.2 V voltage, by default. The LDO output voltage is selected through the PWC\_LDOOV register. The maximum operating frequency for the system depends on the selected output voltage. Refer to *AT32F402/405 Series Datasheet* for details. The LDO output voltage is changeable only when the HEXT or HICK is used as system clock.

#### LDO output voltage regulation

- 1) Select HICK or HEXT as system clock;
- 2) Change LDO voltage (LDOOVSEL[1:0]);
- 3) Set the FLASH\_PSR register;
- 4) Set the targeted frequency for PLL-related registers, enable PLL, and wait for PLL\_STBL;
- 5) Set pre-division factors for AHB and APB;
- 6) Enable auto step-by-step frequency switch function when PLL frequency is greater than 108 MHz;
- 7) Switch the system clock to PLL.

## 3.6 Power saving modes

When the CPU does not need to be kept running, there are three types of low-power modes available (Sleep mode, Deepsleep mode and Standby mode) to save power. Users can select the mode that gives the best compromise according to the low-power consumption, short startup time and available wakeup sources. In addition, the power consumption in Run mode can be reduced by slowing down the system clocks or gating the clocks to the APB and AHB peripherals when they are not used.

#### Sleep mode

The Sleep mode is entered by executing WFI or WFE instruction. There are two options to select the Sleep mode entry mechanism through the SLEEPONEXIT bit in the Cortex®-M4F system control register.

##### SLEEP-NOW mode:

When SLEEPDEEP=0 and SLEEPONEXIT=0, the MCU enters Sleep mode as soon as WFI or WFE instruction is executed.

##### SLEEP-ON-EXIT mode:

When SLEEPDEEP=0 and SLEEPONEXIT=1, by executing the WFI instruction, the MCU enters Sleep mode as soon as the system exits the lowest-priority interrupt service routine.

In Sleep mode, all clocks and LDO work normally except CPU clocks (stopped), and all I/O pins keep the same state as in Run mode. The LDO provides power (for CPU core, memory and embedded peripherals) as it is in normal power consumption mode.

- 1) If the WFI is executed to enter Sleep mode, any peripheral interrupt can wake up the device from Sleep mode.
- 2) If the WFE is executed to enter Sleep mode, the MCU exits Sleep mode as soon as an event occurs. The wakeup event can be generated by the following:

- Enabling a peripheral interrupt (it is not enabled in the NVIC) and enabling the SEVONPEND bit. When the MCU resumes, the peripheral interrupt pending bit and NVIC channel pending bit must be cleared.
- Configuring an internal EXINT line as an event mode to generate a wakeup event.
- The wakeup time required by a WFE instruction is the shortest, since no time is wasted on interrupt entry/exit.

### Deepsleep mode

Deepsleep mode is entered by setting the SLEEPDEEP bit in the Cortex®-M4F system control register and clearing the LPSEL bit in the PWC\_CTRL register before executing WFI or WFE instructions.

The LDO status is selected by setting the VRSEL bit in the power control register (PWC\_CTRL). When VRSEL=0, the LDO works in normal mode. When VRSEL=1, the LDO is set in low-power consumption mode.

In addition, in Deepsleep mode, with VRSEL=1 and LDO in low-power mode, the system power consumption can be further reduced by setting the VREXLPE bit.

In Deepsleep mode, all clocks in 1.2 V domain are stopped, and both HICK and HEXT oscillators are disabled. The LDO supplies power to the 1.2 V domain in normal mode or low-power mode. All I/O pins keep the same state as in Run mode. SRAM and register contents are preserved.

- 1) If the WFI is executed to enter Deepsleep mode, the interrupt generated on any external interrupt line in Interrupt mode can wake up the system from Deepsleep mode.
- 2) If the WFE is executed to enter Deepsleep mode, the event generated on any external interrupt line in Event mode can wake up the system from Deepsleep mode.

When the MCU exits the Deepsleep mode, the HICK RC oscillator is enabled and selected a system clock after stabilization. When the LDO operates in low-power mode, an additional wakeup delay is incurred for the reason that the LDO must be stabilized before the system is waken from the Deepsleep mode.

### Low-power Deepsleep LDO voltage regulation process (note that Sleep and Standby modes have no such limits)

- 1) Select HICK as system clock
- 2) Change LDO voltage to 1.1 V by setting the LDOOVSEL[1:0] bit
- 3) Set the LDO in low-power mode by setting the VRSEL bit
- 4) System enters Deepsleep state
- 5) System exits Deepsleep state (if wakeup conditions are met)
- 6) Change LDO voltage by setting the LDOOVSEL[1:0] bit
- 7) Set the FLASH\_PSR register
- 8) If the HEXT is used as PLL clock source, enable HEXT and wait for HEXTSTBL
- 9) Set the targeted frequency for PLL-related registers
- 10) Enable PLL and wait for PLL\_STBL
- 11) Set pre-division factors for AHB and APB
- 12) Enable auto step-by-step frequency switch function when PLL frequency is greater than 108 MHz
- 13) Switch system clock to PLL

Note: If the clock, after low-power mode is waken up, needs to keep the same state as in low-power mode, the above-mentioned steps 3/9/11 can be ignored.

### Standby mode

Standby mode can achieve the lowest power consumption for the device. In this mode, the LDO is disabled. The whole 1.2 V domain, PLL, HICK and HEXT oscillators are also powered off. SRAM and register contents are lost. Only VDD/VDDA domain remain supplied.

The Standby mode is entered by the following procedures:

- Set the SLEEPDEEP bit in the Cortex®-M4F system control register
- Set the LPSEL bit in the PWC\_CTRL register
- Clear the SWEF bit in the PWC\_CTRLSTS register
- Execute a WFI or WFE instruction

In Standby mode, registers in the battery-powered domain, ERTC registers and standby circuitry remain supplied.

In Standby mode, all I/O pins remain in a high-impedance state except reset pins, TAMPER pins that set as anti-tamper or calibration output, and the wakeup pins enabled.

The MCU exits the Standby mode when a rising edge on the WKUP pin, a rising edge of an ERTC alarm event, an ERTC tamper event, ERTC timestamp, ERTC periodic automatic wakeup, an external reset (NRST pin) or a WDT reset occurs.

### Debug mode

By default, the debug connection is lost if the MCU enters Deepsleep mode or Standby mode while debugging. The reason is that the Cortex®-M4F is no longer clocked. However, the software can be debugged even in the low-power mode by setting some configuration bits in the DEBUG control register (DEBUG\_CTRL).

## 3.7 PWC registers

These peripheral registers can be accessed by half-words (16 bits) or words (32 bits).

Table 3-1 PWC register map and reset values

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| PWC_CTRL    | 0x00   | 0x0000 0000 |
| PWC_CTRLSTS | 0x04   | 0x0000 0000 |
| PWC_LDOOV   | 0x10   | 0x0000 0012 |

### 3.7.1 Power control register (PWC\_CTRL)

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                 |
|----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:9 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                                                  |
| Bit 8    | BPWEN    | 0x0         | rw   | <p>Battery powered domain write enable<br/>0: Disabled<br/>1: Enabled</p> <p>Note:<br/>After reset, the battery powered domain write access is disabled. To write, this bit must be set.</p>                                                                |
| Bit 7:5  | PVMSEL   | 0x0         | rw   | <p>Power voltage monitoring boundary select<br/>000: Unused, not configurable<br/>001: 2.3 V<br/>010: 2.4 V<br/>011: 2.5 V<br/>100: 2.6 V<br/>101: 2.7 V<br/>110: 2.8 V<br/>111: 2.9 V</p>                                                                  |
| Bit 4    | PVMEN    | 0x0         | rw   | <p>Power voltage monitoring enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                       |
| Bit 3    | CLSEF    | 0x0         | wo   | <p>Clear SEF flag<br/>0: No effect<br/>1: Clear the SEF flag</p> <p>Note: This bit is cleared by hardware after clearing the SEF flag. Reading this bit at any time will return all zero.</p>                                                               |
| Bit 2    | CLSWEF   | 0x0         | wo   | <p>Clear SWEF flag<br/>0: No effect<br/>1: Clear the SWEF flag</p> <p>Note:<br/>Clear the SWEF flag after two system clock cycles.<br/>This bit is cleared by hardware after clearing the SWEF flag. Reading this bit at any time will return all zero.</p> |

|       |       |     |    |                                                                                                                 |
|-------|-------|-----|----|-----------------------------------------------------------------------------------------------------------------|
| Bit 1 | LPSEL | 0x0 | rw | Low-power mode select when Cortex®-M4F is in Deepsleep mode<br>0: Enter Deepsleep mode<br>1: Enter Standby mode |
| Bit 0 | VRSEL | 0x0 | rw | LDO state select in Deepsleep mode<br>0: Enabled<br>1: Low-power consumption mode                               |

### 3.7.2 Power control/status register (PWC\_CTRLSTS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 13    | SWPEN6   | 0x0         | rw   | Standby wake-up pin6 enable<br>0: Disabled (this pin can be used as a general-purpose I/O)<br>1: Enabled (this pin is forced in input pull-down mode, and no longer used as a general-purpose I/O)<br><u>Note: This bit is cleared by hardware after system reset.</u>                                                                                                                                                                                             |
| Bit 12:10 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 9     | SWPEN2   | 0x0         | rw   | Standby wake-up pin2 enable<br>0: Disabled (this pin can be used as a general-purpose I/O)<br>1: Enabled (this pin is forced in input pull-down mode, and no longer used as a general-purpose I/O)<br><u>Note: This bit is cleared by hardware after system reset.</u>                                                                                                                                                                                             |
| Bit 8     | SWPEN1   | 0x0         | rw   | Standby wake-up pin1 enable<br>0: Disabled (this pin can be used as a general-purpose I/O)<br>1: Enabled (this pin is forced in input pull-down mode, and no longer used as a general-purpose I/O)<br><u>Note: This bit is cleared by hardware after system reset.</u>                                                                                                                                                                                             |
| Bit 7:3   | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 2     | PVMOF    | 0x0         | ro   | Power voltage monitoring output flag<br>0: Power voltage is higher than the threshold<br>1: Power voltage is lower than the threshold<br><u>Note: The power voltage monitoring is stopped in Standby mode.</u>                                                                                                                                                                                                                                                     |
| Bit 1     | SEF      | 0x0         | ro   | Standby mode entry flag<br>0: Device is not in Standby mode<br>1: Device is in Standby mode<br><u>Note: This bit is set by hardware (enter Standby mode) and cleared by POR/LVR or by setting the CLSEF bit.</u>                                                                                                                                                                                                                                                   |
| Bit 0     | SWEF     | 0x0         | ro   | Standby wake-up event flag<br>0: No wakeup event occurred<br>1: A wakeup event occurred<br><u>Note:</u><br>This bit is set by hardware (on a wakeup event) and is cleared by POR/LVR or by setting the CLSWEF bit.<br>A wakeup event is generated by one of the following:<br>– When the rising edge on the Standby wakeup pin occurs;<br>– When the ERTC alarm event occurs;<br>– If the Standby wakeup pin is enabled when the Standby wakeup pin level is high. |

### 3.7.3 LDO output voltage select register (PWC\_LDOOV)

| Bit      | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:5 | Reserved  | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 4    | VREXLPPEN | 0x1         | rw   | <p>Voltage regulator extra low power mode enable<br/>This bit works together with the LPSEL and VRSEL bits in the PWC_CTRL register, and it is valid when VRSEL = 1 and the chip enters Deepsleep mode.</p> <p>0: Disabled<br/>1: Enabled</p> <p>Note: To enable extra low power mode, set the VREXLPPEN bit before setting LPSEL and VRSEL bits.</p> <p>Note: after DEEPSLEEP mode is entered while this bit is set, LDO driving capability is limited, so it is prohibited to enable DEEPSLEEP DEBUG.</p> |
| Bit 3:2  | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 1:0  | LDOOVSEL  | 0x02        | rw   | <p>Voltage regulator output voltage select</p> <p>00: 1.1 V<br/>01: Reserved<br/>10: 1.2 V<br/>11: 1.3 V</p>                                                                                                                                                                                                                                                                                                                                                                                                |

## 4 Clock and reset manage (CRM)

### 4.1 Clock

AT32F402/405 series provide different clock sources, including HEXT oscillator clock, HICK oscillator clock, PLL clock, LEXT oscillator clock and LICK oscillator clock.

Figure 4-1 AT32F405 clock tree



Figure 4-2 AT32F402 clock tree



HEXT: High speed external crystal

LEXT: Low speed external crystal

HICK: High speed internal clock

LICK: Low speed internal clock

AHB, APB2 and APB1 all support multiple frequency divisions. The AHB domain has a maximum frequency of 216 MHz, APB1 domain is up to 120 MHz, and APB2 is up to 216 MHz.

#### 4.1.1 Clock sources

- High-speed external oscillator (HEXT)

The HEXT includes two clock sources: crystal/ceramic resonator and bypass clock.

The HEXT crystal/ceramic resonator is connected externally to a 4~25 MHz HEXT crystal that produces a highly accurate clock for the system. The HEXT clock signal is not released until it becomes stable.

An external clock source can be provided by HEXT bypass. Its frequency can be up to 25 MHz. The external clock signal should be connected to the HEXT\_IN pin while the HEXT\_OUT pin should be released for GPIO control.

- High-speed internal clock (HICK)

The HICK oscillator is clocked by a high-speed RC in the microcontroller. The internal frequency of the HICK clock is 48 MHz. Although it is less accurate, its startup time is shorter than the HEXT crystal oscillator. The HICK clock frequency of each device is calibrated by ARTERY to 1% accuracy (TA=25°C) in factory. The factory-trimmed value is loaded into the HICKCAL[7:0] bit of the clock control register. The RC oscillator speed may be affected by voltage or temperature variations. Thus the HICK frequency can be trimmed by setting the HICKTRIM[5:0] bit in the clock control register.

The HICK clock signal is not released until it becomes stable.

- PLL clock

The HICK or HEXT clock can be used as an input clock source of the PLL. The PLL input clock, after being divided by a pre-divider internally, is sent to the VCO for frequency multiplication, and the VCO output frequency is output after being divided by a post-divider. At the same time, the clock after pre-divider must remain between 2 MHz and 16 MHz, and the VCO operating frequency must be kept between 500 MHz and 1000 MHz. The PLL must be configured before being enabled. The reason is that

the configuration parameters cannot be changed once the PLL is enabled. The PLL clock signal is not released until it becomes stable.

PLL formula:

PLL output clock = PLL input clock x PLL frequency multiplication factor / (PLL pre-divider factor x PLL post-divider factor)

500 MHz <= PLL input clock x PLL frequency multiplication factor / PLL pre-divider factor <= 1000 MHz

2 MHz <= PLL input clock / PLL pre-divider factor <= 16 MHz

For example, when the PLL input clock is 25 MHz, the PLL output frequency =  $25 \times 160 / (5 \times 4) = 200$  MHz.

- Low-speed external oscillator (LEXT)

The LEXT oscillator provides two clock sources: LEXT crystal/ceramic resonator and LEXT bypass.

LEXT crystal/ceramic resonator:

The LEXT crystal/ceramic resonator provides a low-power and accurate 32.768 KHz low-speed clock source. The LEXT clock signal is not released until it becomes stable.

- LEXT bypass clock

In LEXT bypass mode, an external clock source with a frequency of 32.768 KHz can be provided. The external clock signal should be connected to the LEXT\_IN pin, and the LEXT\_OUT pin should be released for GPIO control.

- Low-speed internal RC oscillator (LICK)

The LICK oscillator is clocked by an internal low-speed RC oscillator. The clock frequency is between 30 KHz and 60 KHz. It acts as a clock source that can be kept running in Deepsleep mode and Standby mode for watchdog and auto wakeup unit.

The LICK clock signal is not released until it becomes stable.

## 4.1.2 System clock

After a system reset, the HICK oscillator is selected as system clock. The system clock can make flexible switch among HICK oscillator, HEXT oscillator and PLL clock. However, a switch from one clock source to another occurs only if the target clock source becomes stable. When the HICK oscillator is used directly or indirectly through the PLL as the system clock, it cannot be stopped.

## 4.1.3 Peripheral clock

Most peripherals use HCLK, PCLK1 or PCLK2 clock. The individual peripherals have their dedicated clocks.

System Tick timer (SysTick) is clocked by HCLK or HCLK/8.

ADC is clocked by HCLK divided by 2, 3, 4, 5...17.

The timers are clocked by APB1/2. In particular, if the APB prescaler is 1, the timer clock frequency is equal to that of APB1/2; otherwise, the timer clock frequency doubles that of the APB1/2 frequency.

The USB clock source can be switched between HICK and PLLU. If the HICK is selected as a clock source, it should be set as 48 MHz. If the PLLU is selected as a clock source, it should be configured as 48 MHz clock output.

ERTC clock source: divided HEXT oscillator, LEXT oscillator and LICK oscillator. Once the clock source is selected, it cannot be altered unless a reset of battery powered domain is performed. If the LEXT is used as an ERTC clock, the ERTC is not affected when the VDD is powered off. If the HEXT or LICK is selected as an ERTC clock, the ERTC state is not guaranteed when both HEXT and LICK are powered off.

Watchdog is clocked by LICK oscillator. If the watchdog is enabled by either hardware option or software access, the LICK oscillator is forced ON. The clock is provided to the watchdog only after the LICK oscillator temporization.

## 4.1.4 Clock fail detector

The clock fail detector (CFD) is designed to respond to HEXT clock failure when the HEXT is used as the system clock, directly or indirectly. If a failure is detected on the HEXT clock, a clock failure event is sent to the brake input of TMR1/9/10/11/12/13/14 and a CFD interrupt is generated. This interrupt is

directly linked to CPU NMI so that the software can perform rescue operations. The NMI interrupt keeps executing until the CFD interrupt pending bit is cleared. This is why the CFD interrupt has to be cleared in the NMI service routine. The HEXT clock failure will result in a switch of the system clock to the HICK clock, the CFD to be disabled, HEXT clock to be stopped, and even PLL to be disabled if the HEXT is selected as system clock through PLL.

#### 4.1.5 Auto step-by-step system clock switch

The automatic frequency switch is designed to ensure a smooth and stable switch of system frequency when the system clock source is switched from others to the PLL or when the AHB prescaler factor is changed from large to small. When the operational target is larger than 108 MHz, it is recommended to enable the automatic frequency switch. Once it is enabled, the AHB bus is halted by hardware till the completion of the switch. During this switch period, the DMA remain working, and the interrupt events are recorded and then handled by NVIC when the AHB bus resumes.

#### 4.1.6 Internal clock output

The microcontroller allows the internal clock signal to be output to external CLKOUT pin. That is, ADCCLK, USBFS48M, SCLK, LICK, LEXT, HICK, HEXT and PLLCLK can be used as CLKOUT clock. When being used as the CLKOUT clock output pin, the corresponding GPIO port registers must be configured accordingly.

#### 4.1.7 Interrupts

The microcontroller specifies a stable flag for each clock source. As a result, when a clock source is enabled, it is possible to determine if the clock is stable by checking the flag pertaining to the clock source. An interrupt request is generated when the interrupt corresponding to the clock source is enabled.

If a failure is detected on the HEXT clock, the CFD interrupt is generated. Such interrupt is directly linked to CPU NMI.

### 4.2 Reset

#### 4.2.1 System reset

AT32F402/405 series provide the following system reset sources:

- NRST reset: on the external NRST pin
- WDT reset: watchdog overflow
- WWDT reset: window watchdog overflow
- CPU software reset: Cortex®-M4F software reset
- Low-power management reset: This type of reset is enabled when entering Standby mode (by clearing the nSTDBY\_RST bit in the user system data area), or it is enabled when entering Deepsleep mode (by clearing the nDEPSLP\_RST bit in the user system data area)
- POR reset: power-on reset
- LVR reset: low voltage reset
- When exiting Standby mode

NRST reset, WDT reset, WWDT reset, software reset and low-power management reset sets all registers to their reset values except the clock control/status register (CRM\_CTRLSTS) and battery powered domain registers. The power-on reset, low voltage reset or reset generated when exiting Standby mode sets all registers to their reset values except the battery powered domain registers.

Figure 4-3 System reset circuit



## 4.2.2 Battery powered domain reset

Battery powered domain has two specific reset sources:

- Software reset: triggered by setting the BPDRST bit in the battery powered domain control register (CRM\_BPDC)
- VDD power on, if it has been powered off

Software reset affects only the battery powered domain.

## 4.3 CRM registers

These peripheral registers can be accessed by bytes (8 bits), half-words (16 bits) and words (32 bits).

Table 4-1 CRM register map and reset values

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| CRM_CTRL     | 0x000  | 0x0000 XX83 |
| CRM_PLLCFG   | 0x004  | 0x0000 07C1 |
| CRM_CFG      | 0x008  | 0x4000 0000 |
| CRM_CLKINT   | 0x00C  | 0x0000 0000 |
| CRM_AHBRST1  | 0x010  | 0x0000 0000 |
| CRM_AHBRST2  | 0x014  | 0x0000 0000 |
| CRM_AHBRST3  | 0x018  | 0x0000 0000 |
| CRM_APB1RST  | 0x020  | 0x0000 0000 |
| CRM_APB2RST  | 0x024  | 0x0000 0000 |
| CRM_AHBEN1   | 0x030  | 0x0000 0000 |
| CRM_AHBEN2   | 0x034  | 0x0000 0000 |
| CRM_AHBEN3   | 0x038  | 0x0000 0000 |
| CRM_APB1EN   | 0x040  | 0x0000 0000 |
| CRM_APB2EN   | 0x044  | 0x0000 0000 |
| CRM_AHBLPEN1 | 0x050  | 0x6141 902F |
| CRM_AHBLPEN2 | 0x054  | 0x0000 0080 |
| CRM_AHBLPEN3 | 0x058  | 0x0000 0002 |
| CRM_APB1LPEN | 0x060  | 0xD2FE C9B7 |
| CRM_APB2LPEN | 0x064  | 0xA017 5131 |
| CRM_BPDC     | 0x070  | 0x0000 0000 |
| CRM_CTRLSTS  | 0x074  | 0x0C00 0000 |
| CRM_OTGHS    | 0x078  | 0x0100 0000 |
| CRM_MISC1    | 0x0A0  | 0x000F 0000 |
| CRM_MISC2    | 0x0A4  | 0x4000 000D |

### 4.3.1 Clock control register (CRM\_CTRL)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                                                                                                   |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:27 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                    |
| Bit 26    | PLLUSTBL | 0x0         | ro   | PLLU clock stable<br>This bit is set by hardware after PLLU is ready.<br>0: PLLU clock is not ready<br>1: PLLU clock is ready |

|           |          |      |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|----------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 25    | PLLSTBL  | 0x0  | ro   | PLL clock stable<br>This bit is set by hardware after PLL is ready.<br>0: PLL is not ready<br>1: PLL is ready                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 24    | PLLEN    | 0x0  | rw   | PLL enable<br>This bit is set and cleared by software. It can also be cleared by hardware when entering Standby or Deepsleep mode. When the PLL clock is used as system clock, this bit cannot be cleared.<br>0: PLL is disabled<br>1: PLL is enabled                                                                                                                                                                                                                         |
| Bit 23:20 | Reserved | 0x0  | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 19    | CFDEN    | 0x0  | rw   | Clock fail detector enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 18    | HEXTBYPS | 0x0  | rw   | High-speed external crystal bypass<br>This bit can be set only if the HEXT is disabled.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                          |
| Bit 17    | HEXTSTBL | 0x0  | ro   | High-speed external crystal stable<br>This bit is set by hardware after HEXT becomes stable.<br>0: HEXT is not ready<br>1: HEXT is ready                                                                                                                                                                                                                                                                                                                                      |
| Bit 16    | HEXTEN   | 0x0  | rw   | High-speed external crystal enable<br>This bit is set and cleared by software. It can also be cleared by hardware when entering Standby or Deepsleep mode. When the HEXT clock is used as system clock, this bit cannot be cleared<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                               |
| Bit 15:8  | HICKCAL  | 0xXX | rw   | High-speed internal clock calibration<br>The default value of this field is the initial factory calibration value.<br>When the HICK output frequency is 48 MHz, it needs adjust 240 KHz (design value) based on this frequency for each HICKCAL value change. When HICK output frequency is 8 MHz, it needs adjust 40 KHz (design value) based on this frequency for each HICKCAL value change.<br>Note: This bit can be written only if the HICKCAL_KEY[7:0] is set as 0x5A. |
| Bit 7:2   | HICKTRIM | 0x20 | rw   | High-speed internal clock trimming<br>These bits work with the HICKCAL[7:0] to determine the HICK oscillator frequency. The default value is 32, which can trim the HICK to be $\pm 1\%$ .                                                                                                                                                                                                                                                                                    |
| Bit 1     | HICKSTBL | 0x1  | ro   | High-speed internal clock stable<br>This bit is set by hardware after HICK is ready.<br>0: HICK is not ready<br>1: HICK is ready                                                                                                                                                                                                                                                                                                                                              |
| Bit 0     | HICKEN   | 0x1  | rw   | High-speed internal clock enable<br>This bit is set and cleared by software. It can also be cleared by hardware when entering Standby or Deepsleep mode. When a HEXT clock failure occurs, this bit can also be set. When the HICK clock is used as system clock, this bit cannot be cleared<br>0: Disabled<br>1: Enabled                                                                                                                                                     |

### 4.3.2 PLL clock configuration register (CRM\_PLLCFG)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31    | Reserved | 0x0         | resd | Kept at its reset value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 30    | PLLRCs   | 0x0         | rw   | PLL reference clock select<br>The PLL reference clock source is selected by setting "1" or clearing this bit by software. This bit can be written only when the PLL is disabled.<br>0: HICK is used as PLL reference clock<br>1: HEXT is used as PLL reference clock                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 29    | PLL_U_EN | 0x0         | rw   | PLL_U enable<br>This bit is set and cleared by software. It can also be cleared by hardware when entering Standby or Deepsleep mode.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 28:23 | Reserved | 0x0         | resd | Kept at its reset value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 22:20 | PLL_FU   | 0x0         | rw   | PLL_U post-division<br>PLL_FU range (0~7)<br>This bit cannot be set when PLL is enabled.<br>000: PLL_U post-division=11<br>001: PLL_U post-division=13<br>010: PLL_U post-division=12<br>011: PLL_U post-division=14<br>100: PLL_U post-division=16<br>101: PLL_U post-division=18<br>110: PLL_U post-division=20<br>111: PLL_U post-division=11<br>Note to the correlation between the PLL_FR value and post-division factor.                                                                                                                                                                                                                                                    |
| Bit 19:16 | PLL_FP   | 0x0         | rw   | PLLP post-division<br>PLL_FP range (0~15)<br>This bit cannot be set when PLL is enabled.<br>0000: PLLP post-division=1<br>0001: PLLP post-division=2<br>0010: PLLP post-division=4<br>0011: PLLP post-division=6<br>0100: PLLP post-division=8<br>0101: PLLP post-division=10<br>0110: PLLP post-division=12<br>0111: PLLP post-division=14<br>1000: PLLP post-division=16<br>1001: PLLP post-division=18<br>1010: PLLP post-division=20<br>1011: PLLP post-division=22<br>1100: PLLP post-division=24<br>1101: PLLP post-division=26<br>1110: PLLP post-division=28<br>1111: PLLP post-division=30<br>Note to the correlation between the PLL_FR value and post-division factor. |
| Bit 15    | Reserved | 0x0         | resd | Kept at its reset value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

|          |          |       |      |                                                                                                                                                                               |
|----------|----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |       |      | PLL multiplication factor<br>PLL_NS range (31~500)<br>This bit cannot be set when PLLEN is enabled.<br>00000000 ~ 00001110: Forbidden<br>00001111: 31                         |
| Bit 14:6 | PLL_NS   | 0x01F | rw   | 00010000: 32<br>00010001: 33<br>.....<br>111110011: 499<br>111110100: 500<br>111110101~111111111: Forbidden                                                                   |
| Bit 5:4  | Reserved | 0x0   | resd | Kept at its reset value.                                                                                                                                                      |
|          |          |       |      | PLL pre-division<br>PLL_MS range (1~15)<br>This bit cannot be set when PLLEN is enabled.<br>0000: Forbidden<br>0001: 1<br>0010: 2<br>0011: 3<br>.....<br>1110: 14<br>1111: 15 |
| Bit 3:0  | PLL_MS   | 0x1   | rw   |                                                                                                                                                                               |

Note: PLL clock formulas:

PLLP output clock = PLL input clock x PLL frequency multiplication factor / (PLL pre-divider factor x PLL\_FU post-divider factor)

PLLU output clock = PLL input clock x PLL frequency multiplication factor / (PLL pre-divider factor x PLL\_FU post-divider factor)

500 MHz <= PLL input clock x PLL frequency multiplication factor / PLL pre-divider factor <= 1000 MHz

2 MHz <= PLL input clock / PLL pre-divider factor <= 16 MHz

### 4.3.3 Clock configuration register (CRM\_CFG)

Access: 0 to 2 wait states, accessible by words, half-words and bytes; 1 or 2 wait states are inserted only when the access occurs during a clock source switch.

| Bit       | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:30 | CLKOUT_SEL1 | 0x1         | rw   | Clock output selection 1<br>This bit is set and cleared by software.<br>00: System clock (SCLK) output<br>01: Secondary clock output, selected by the CLKOUT_SEL2 bit in the CRM_MISC1 register<br>10: External oscillator clock (HEXT) output<br>11: PLL clock output<br>Note: This clock output may be cut off during the startup and switch of CLKOUT clock source. While being used as an output to CLKOUT pin, the system clock output must be no more than 50 MHz (the maximum frequency of an I/O port). |
| Bit 29:27 | CLKOUTDIV1  | 0x0         | rw   | Clock output division1<br>0xx: CLKOUT<br>100: CLKOUT/2<br>101: CLKOUT/3<br>110: CLKOUT/4<br>111: CLKOUT/5                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 26:24 | Reserved    | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 23:22 | I2SF5CLKSEL | 0x0         | resd | I2SF5 clock source selection<br>00: System Clock<br>01: PLL<br>10: HICK                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|           |          |      |      |                                                                                                                                                                                                                                                                                                                             |
|-----------|----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |          |      |      | 11: External input clock<br>Kept at its default value.                                                                                                                                                                                                                                                                      |
| Bit 21    | Reserved | 0x0  | resd |                                                                                                                                                                                                                                                                                                                             |
| Bit 20:16 | ERTCDIV  | 0x00 | rw   | HEXT division for ERTC clock<br>This field is set and cleared by software to divide the HEXT for ERTC clock.<br>These bits must be configured before selecting the ERTC clock source.<br>00000: Forbidden<br>00001: Forbidden<br>00010: HEXT/2<br>00011: HEXT/3<br>00100: HEXT/4<br>...<br>11110: HEXT/30<br>11111: HEXT/31 |
| Bit 15:13 | APB2DIV  | 0x0  | rw   | APB2 division<br>The divided HCLK is used as APB2 clock.<br>0xx: Not divided<br>100: HCLK/2<br>101: HCLK/4<br>110: HCLK/8<br>111: HCLK/16                                                                                                                                                                                   |
| Bit 12:10 | APB1DIV  | 0x0  | rw   | APB1 division<br>The divided HCLK is used as APB1 clock.<br>0xx: Not divided<br>100: HCLK/2<br>101: HCLK/4<br>110: HCLK/8<br>111: HCLK/16                                                                                                                                                                                   |
| Bit 9:8   | Reserved | 0x0  | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                  |
| Bit 7:4   | AHBDIV   | 0x0  | rw   | AHB division<br>0xxx: SCLK not divided<br>1000:SCLK/2 1100:SCLK/64<br>1001:SCLK/4 1101:SCLK/128<br>1010:SCLK/8 1110:SCLK/256<br>1011:SCLK/16 1111:SCLK/512                                                                                                                                                                  |
| Bit 3:2   | SCLKSTS  | 0x0  | ro   | System clock select status<br>00: HICK<br>01: HEXT<br>10: PLL<br>11: Reserved. Kept at its default value.                                                                                                                                                                                                                   |
| Bit 1:0   | SCLKSEL  | 0x0  | rw   | System clock select<br>00: HICK<br>01: HEXT<br>10: PLL<br>11: Reserved. Kept at its default value.                                                                                                                                                                                                                          |

#### 4.3.4 Clock interrupt register (CRM\_CLKINT)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name       | Reset value | Type | Description                                                                                                   |
|-----------|------------|-------------|------|---------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | Reserved   | 0x00        | resd | Kept at its default value.                                                                                    |
| Bit 23    | CFDFC      | 0x0         | wo   | Clock failure detection interrupt clear<br>Writing "1" by software to clear CFDF.<br>0: No effect<br>1: Clear |
| Bit 22:21 | Reserved   | 0x0         | resd | Kept at its default value.                                                                                    |
| Bit 20    | PLLSTBLFC  | 0x0         | wo   | PLL stable flag clear<br>Writing "1" by software to clear PLLSTBLF.<br>0: No effect<br>1: Clear               |
| Bit 19    | HEXTSTBLFC | 0x0         | wo   | HEXT stable flag clear<br>Writing "1" by software to clear HEXTSTBLF.                                         |

|           |             |     |      |                                                                                                                                            |
|-----------|-------------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------|
|           |             |     |      | 0: No effect<br>1: Clear                                                                                                                   |
| Bit 18    | HICKSTBLFC  | 0x0 | wo   | HICK stable flag clear<br>Writing "1" by software to clear HICKSTBLF.<br>0: No effect<br>1: Clear                                          |
| Bit 17    | LEXTSTBLFC  | 0x0 | wo   | LEXT stable flag clear<br>Writing "1" by software to clear LEXTSTBLF.<br>0: No effect<br>1: Clear                                          |
| Bit 16    | LICKSTBLFC  | 0x0 | wo   | LICK stable flag clear<br>Writing "1" by software to clear LICKSTBLF.<br>0: No effect<br>1: Clear                                          |
| Bit 15:13 | Reserved    | 0x0 | resd | Kept at its default value.                                                                                                                 |
| Bit 12    | PLLSTBLIEN  | 0x0 | rw   | PLL stable interrupt enable<br>0: Disabled<br>1: Enabled                                                                                   |
| Bit 11    | HEXTSTBLIEN | 0x0 | rw   | HEXT stable interrupt enable<br>0: Disabled<br>1: Enabled                                                                                  |
| Bit 10    | HICKSTBLIEN | 0x0 | rw   | HICK stable interrupt enable<br>0: Disabled<br>1: Enabled                                                                                  |
| Bit 9     | LEXTSTBLIEN | 0x0 | rw   | LEXT stable interrupt enable<br>0: Disabled<br>1: Enabled                                                                                  |
| Bit 8     | LICKSTBLIEN | 0x0 | rw   | LICK stable interrupt enable<br>0: Disabled<br>1: Enabled                                                                                  |
| Bit 7     | CFDF        | 0x0 | ro   | Clock failure detection flag<br>This bit is set by hardware when the HEXT clock failure occurs.<br>0: No clock failure<br>1: Clock failure |
| Bit 6:5   | Reserved    | 0x0 | resd | Kept at its default value.                                                                                                                 |
| Bit 4     | PLLSTBLF    | 0x0 | ro   | PLL stable flag<br>This bit is set by hardware.<br>0: PLL is not ready<br>1: PLL is ready                                                  |
| Bit 3     | HEXTSTBLF   | 0x0 | ro   | HEXT stable flag<br>This bit is set by hardware.<br>0: HEXT is not ready<br>1: HEXT is ready                                               |
| Bit 2     | HICKSTBLF   | 0x0 | ro   | HICK stable flag<br>This bit is set by hardware.<br>0: HICK is not ready<br>1: HICK is ready                                               |
| Bit 1     | LEXTSTBLF   | 0x0 | ro   | LEXT stable flag<br>This bit is set by hardware.<br>0: LEXT is not ready<br>1: LEXT is ready                                               |
| Bit 0     | LICKSTBLF   | 0x0 | ro   | LICK stable flag<br>This bit is set by hardware.<br>0: LICK is not ready<br>1: LICK is ready                                               |

#### 4.3.5 AHB peripheral reset register 1 (CRM\_AHBRST1)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                              |
|-----------|----------|-------------|------|----------------------------------------------------------|
| Bit 31:30 | Reserved | 0x0         | resd | Kept at its default value.                               |
| Bit 29    | OTGHSRST | 0x0         | rw   | OTGHS reset<br>0: Does not reset OTGHS<br>1: Reset OTGHS |
| Bit 28:25 | Reserved | 0x0         | resd | Kept at its default value.                               |
| Bit 24    | DMA2RST  | 0x0         | rw   | DMA2 reset                                               |

|           |          |       |      |                                                                      |
|-----------|----------|-------|------|----------------------------------------------------------------------|
|           |          |       |      | 0: Does not reset DMA2<br>1: Reset DMA2                              |
| Bit 23    | Reserved | 0x0   | resd | Kept at its default value.                                           |
| Bit 22    | DMA1RST  | 0x0   | rw   | DMA1 reset<br>0: Does not reset DMA1<br>1: Reset DMA1                |
| Bit 21:13 | Reserved | 0x000 | resd | Kept at its default value.                                           |
| Bit 12    | CRCRST   | 0x0   | rw   | CRC reset<br>0: Does not reset CRC<br>1: Reset CRC                   |
| Bit 11:6  | Reserved | 0x00  | resd | Kept at its default value.                                           |
| Bit 5     | GPIOFRST | 0x0   | rw   | IO port F reset<br>0: Does not reset IO port F<br>1: Reset IO port F |
| Bit 4     | Reserved | 0x0   | resd | Kept at its default value.                                           |
| Bit 3     | GPIODRST | 0x0   | rw   | IO port D reset<br>0: Does not reset IO port D<br>1: Reset IO port D |
| Bit 2     | GPIOCRST | 0x0   | rw   | IO port C reset<br>0: Does not reset IO port C<br>1: Reset IO port C |
| Bit 1     | GPIOBRST | 0x0   | rw   | IO port B reset<br>0: Does not reset IO port B<br>1: Reset IO port B |
| Bit 0     | GPIOARST | 0x0   | rw   | IO port A reset<br>0: Does not reset IO port A<br>1: Reset IO port A |

#### 4.3.6 AHB peripheral reset register 2 (CRM\_AHBRST2)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name      | Reset value | Type | Description                                                 |
|----------|-----------|-------------|------|-------------------------------------------------------------|
| Bit 31:8 | Reserved  | 0x000000    | resd | Kept at its default value.                                  |
| Bit 7    | OTGFS1RST | 0x0         | rw   | OTGFS1 reset<br>0: Does not reset OTGFS1<br>1: Reset OTGFS1 |
| Bit 6:0  | Reserved  | 0x00        | resd | Kept at its default value.                                  |

#### 4.3.7 AHB peripheral reset register 3 (CRM\_AHBRST3)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name     | Reset value | Type | Description                                              |
|----------|----------|-------------|------|----------------------------------------------------------|
| Bit 31:2 | Reserved | 0x00000000  | resd | Kept at its default value.                               |
| Bit 1    | QSPI1RST | 0x0         | rw   | QSPI1 reset<br>0: Does not reset QSPI1<br>1: Reset QSPI1 |
| Bit 0    | Reserved | 0x0         | resd | Kept at its default value.                               |

#### 4.3.8 APB1 peripheral reset register (CRM\_APB1RST)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                                                            |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------|
| Bit 31    | UART8RST | 0x0         | rw   | UART8 reset<br>0: Does not reset UART8<br>1: Reset UART8                               |
| Bit 30    | UART7RST | 0x0         | rw   | UART7 reset<br>0: Does not reset UART7<br>1: Reset UART7                               |
| Bit 29    | Reserved | 0x0         | resd | Kept at its default value.                                                             |
| Bit 28    | PWCRST   | 0x0         | rw   | Power interface reset<br>0: Does not reset power interface<br>1: Reset power interface |
| Bit 27:26 | Reserved | 0x0         | resd | Kept at its default value.                                                             |
| Bit 25    | CAN1RST  | 0x0         | rw   | CAN1 reset<br>0: Does not reset CAN1<br>1: Reset CAN1                                  |

|           |           |     |      |                                                                                              |
|-----------|-----------|-----|------|----------------------------------------------------------------------------------------------|
| Bit 24    | Reserved  | 0x0 | resd | Kept at its default value.                                                                   |
| Bit 23    | I2C3RST   | 0x0 | rw   | I <sup>2</sup> C3 reset<br>0: Does not reset I <sup>2</sup> C3<br>1: Reset I <sup>2</sup> C3 |
| Bit 22    | I2C2RST   | 0x0 | rw   | I <sup>2</sup> C2 reset<br>0: Does not reset I <sup>2</sup> C2<br>1: Reset I <sup>2</sup> C2 |
| Bit 21    | I2C1RST   | 0x0 | rw   | I <sup>2</sup> C1 reset<br>0: Does not reset I <sup>2</sup> C1<br>1: Reset I <sup>2</sup> C1 |
| Bit 20    | USART5RST | 0x0 | rw   | USART5 reset<br>0: Does not reset USART5<br>1: Reset USART5                                  |
| Bit 19    | USART4RST | 0x0 | rw   | USART4 reset<br>0: Does not reset USART4<br>1: Reset USART4                                  |
| Bit 18    | USART3RST | 0x0 | rw   | USART3 reset<br>This bit is set and cleared by software.<br>0: No effect<br>1: Reset USART3  |
| Bit 17    | USART2RST | 0x0 | rw   | USART2 reset<br>0: Does not reset USART2<br>1: Reset USART2                                  |
| Bit 16    | Reserved  | 0x0 | resd | Kept at its default value.                                                                   |
| Bit 15    | SPI3RST   | 0x0 | rw   | SPI3 reset<br>0: Does not reset SPI3<br>1: Reset SPI3                                        |
| Bit 14    | SPI2RST   | 0x0 | rw   | SPI2 reset<br>0: Does not reset SPI2<br>1: Reset SPI2                                        |
| Bit 13:12 | Reserved  | 0x0 | resd | Kept at its default value.                                                                   |
| Bit 11    | WWDTRST   | 0x0 | rw   | Window watchdog reset<br>0: Does not reset window watchdog<br>1: Reset window watchdog       |
| Bit 10:9  | Reserved  | 0x0 | resd | Kept at its default value.                                                                   |
| Bit 8     | TMR14RST  | 0x0 | rw   | Timer14 reset<br>0: Does not reset Timer14<br>1: Reset Timer14                               |
| Bit 7     | TMR13RST  | 0x0 | rw   | Timer13 reset<br>0: Does not reset Timer13<br>1: Reset Timer13                               |
| Bit 6     | Reserved  | 0x0 | resd | Kept at its default value.                                                                   |
| Bit 5     | TMR7RST   | 0x0 | rw   | Timer7 reset<br>0: Does not reset Timer7<br>1: Reset Timer7                                  |
| Bit 4     | TMR6RST   | 0x0 | rw   | Timer6 reset<br>0: Does not reset Timer6<br>1: Reset Timer6                                  |
| Bit 3     | Reserved  | 0x0 | resd | Kept at its default value.                                                                   |
| Bit 2     | TMR4RST   | 0x0 | rw   | Timer4 reset<br>0: Does not reset Timer4<br>1: Reset Timer4                                  |
| Bit 1     | TMR3RST   | 0x0 | rw   | Timer3 reset<br>0: Does not reset Timer3<br>1: Reset Timer3                                  |
| Bit 0     | TMR2RST   | 0x0 | rw   | Timer2 reset<br>0: Does not reset Timer2<br>1: Reset Timer2                                  |

### 4.3.9 APB2 peripheral reset register (CRM\_APB2RST)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name      | Reset value | Type | Description                                                                                     |
|-----------|-----------|-------------|------|-------------------------------------------------------------------------------------------------|
| Bit 31:30 | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 29    | ACCRST    | 0x0         | rw   | ACC reset<br>0: Does not reset ACC<br>1: Reset ACC                                              |
| Bit 28:21 | Reserved  | 0x00        | resd | Kept at its default value.                                                                      |
| Bit 20    | I2SF5RST  | 0x0         | rw   | I <sup>2</sup> SF5 reset<br>0: Does not reset I <sup>2</sup> SF5<br>1: Reset I <sup>2</sup> SF5 |
| Bit 19    | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 18    | TMR11RST  | 0x0         | rw   | Timer11 reset<br>0: Does not reset Timer11<br>1: Reset Timer11                                  |
| Bit 17    | TMR10RST  | 0x0         | rw   | Timer10 reset<br>0: Does not reset Timer10<br>1: Reset Timer10                                  |
| Bit 16    | TMR9RST   | 0x0         | rw   | Timer9 reset<br>0: Does not reset Timer9<br>1: Reset Timer9                                     |
| Bit 15    | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 14    | SCFGRST   | 0x0         | rw   | SCFG reset<br>0: Does not reset SCFG<br>1: Reset SCFG                                           |
| Bit 13    | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 12    | SPI1RST   | 0x0         | rw   | SPI1 reset<br>0: Does not reset SPI1<br>1: Reset SPI1                                           |
| Bit 11:9  | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 8     | ADCRST    | 0x0         | rw   | ADC interface reset<br>0: Does not reset ADC interface<br>1: Reset ADC interface                |
| Bit 7:6   | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 5     | USART6RST | 0x0         | rw   | USART6 reset<br>0: Does not reset USART6<br>1: Reset USART6                                     |
| Bit 4     | USART1RST | 0x0         | rw   | USART1 reset<br>0: Does not reset USART1<br>1: Reset USART1                                     |
| Bit 3:1   | Reserved  | 0x0         | resd | Kept at its default value.                                                                      |
| Bit 0     | TMR1RST   | 0x0         | rw   | TMR1 reset<br>0: Does not reset TMR1<br>1: Reset TMR1                                           |

### 4.3.10 AHB peripheral clock enable register 1 (CRM\_AHBEN1)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                     |
|-----------|----------|-------------|------|-------------------------------------------------|
| Bit 31:30 | Reserved | 0x0         | resd | Kept at its default value.                      |
| Bit 29    | OTGHSEN  | 0x0         | rw   | OTGHS clock enable<br>0: Disabled<br>1: Enabled |
| Bit 28:25 | Reserved | 0x0         | resd | Kept at its default value.                      |
| Bit 24    | DMA2EN   | 0x0         | rw   | DMA2 clock enable<br>0: Disabled<br>1: Enabled  |
| Bit 23    | Reserved | 0x0         | resd | Kept at its default value.                      |
| Bit 22    | DMA1EN   | 0x0         | rw   | DMA1 clock enable<br>0: Disabled<br>1: Enabled  |
| Bit 21:13 | Reserved | 0x000       | resd | Kept at its default value.                      |
| Bit 12    | CRCEN    | 0x0         | rw   | CRC clock enable<br>0: Disabled<br>1: Enabled   |
| Bit 11:6  | Reserved | 0x00        | resd | Kept at its default value.                      |

|       |          |     |      |                                                     |
|-------|----------|-----|------|-----------------------------------------------------|
| Bit 5 | GPIOFEN  | 0x0 | rw   | IO port F clock enable<br>0: Disabled<br>1: Enabled |
| Bit 4 | Reserved | 0x0 | resd | Kept at its default value.                          |
| Bit 3 | GPIODEN  | 0x0 | rw   | IO port D clock enable<br>0: Disabled<br>1: Enabled |
| Bit 2 | GPIOCEN  | 0x0 | rw   | IO port C clock enable<br>0: Disabled<br>1: Enabled |
| Bit 1 | GPIOBEN  | 0x0 | rw   | IO port B clock enable<br>0: Disabled<br>1: Enabled |
| Bit 0 | GPIOAEN  | 0x0 | rw   | IO port A clock enable<br>0: Disabled<br>1: Enabled |

#### 4.3.11 AHB peripheral clock enable register 2 (CRM\_AHBEN2)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name     | Reset value | Type | Description                                      |
|----------|----------|-------------|------|--------------------------------------------------|
| Bit 31:8 | Reserved | 0x0000000   | resd | Kept at its default value.                       |
| Bit 7    | OTGFS1EN | 0x0         | rw   | OTGFS1 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 6:0  | Reserved | 0x00        | resd | Kept at its default value.                       |

#### 4.3.12 AHB peripheral clock enable register 3 (CRM\_AHBEN3)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name     | Reset value | Type | Description                                     |
|----------|----------|-------------|------|-------------------------------------------------|
| Bit 31:2 | Reserved | 0x00000000  | resd | Kept at its default value.                      |
| Bit 1    | QSPI1EN  | 0x0         | rw   | QSPI1 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 0    | Reserved | 0x0         | resd | Kept at its default value.                      |

#### 4.3.13 APB1 peripheral clock enable register (CRM\_APB1EN)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                                 |
|-----------|----------|-------------|------|-------------------------------------------------------------|
| Bit 31    | UART8EN  | 0x0         | rw   | UART8 clock enable<br>0: Disabled<br>1: Enabled             |
| Bit 30    | UART7EN  | 0x0         | rw   | UART7 clock enable<br>0: Disabled<br>1: Enabled             |
| Bit 29    | Reserved | 0x0         | resd | Kept at its default value.                                  |
| Bit 28    | PWCEN    | 0x0         | rw   | Power interface clock enable<br>0: Disabled<br>1: Enabled   |
| Bit 27:26 | Reserved | 0x0         | resd | Kept at its default value.                                  |
| Bit 25    | CAN1EN   | 0x0         | rw   | CAN1 clock enable<br>0: Disabled<br>1: Enabled              |
| Bit 24    | Reserved | 0x0         | resd | Kept at its default value.                                  |
| Bit 23    | I2C3EN   | 0x0         | rw   | I <sup>2</sup> C3 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 22    | I2C2EN   | 0x0         | rw   | I <sup>2</sup> C2 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 21    | I2C1EN   | 0x0         | rw   | I <sup>2</sup> C1 clock enable<br>0: Disabled<br>1: Enabled |

|           |          |     |      |                                                           |
|-----------|----------|-----|------|-----------------------------------------------------------|
| Bit 20    | USART5EN | 0x0 | rw   | USART5 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 19    | USART4EN | 0x0 | rw   | USART4 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 18    | USART3EN | 0x0 | rw   | USART3 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 17    | USART2EN | 0x0 | rw   | USART2 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 16    | Reserved | 0x0 | resd | Kept at its default value.                                |
| Bit 15    | SPI3EN   | 0x0 | rw   | SPI3 clock enable<br>0: Disabled<br>1: Enabled            |
| Bit 14    | SPI2EN   | 0x0 | rw   | SPI2 clock enable<br>0: Disabled<br>1: Enabled            |
| Bit 13:12 | Reserved | 0x0 | resd | Kept at its default value.                                |
| Bit 11    | WWDTEN   | 0x0 | rw   | Window watchdog clock enable<br>0: Disabled<br>1: Enabled |
| Bit 10:9  | Reserved | 0x0 | resd | Kept at its default value.                                |
| Bit 8     | TMR14EN  | 0x0 | rw   | Timer14 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 7     | TMR13EN  | 0x0 | rw   | Timer13 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 6     | Reserved | 0x0 | resd | Kept at its default value.                                |
| Bit 5     | TMR7EN   | 0x0 | rw   | Timer 7 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 4     | TMR6EN   | 0x0 | rw   | Timer 6 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 3     | Reserved | 0x0 | resd | Kept at its default value.                                |
| Bit 2     | TMR4EN   | 0x0 | rw   | Timer 4 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 1     | TMR3EN   | 0x0 | rw   | Timer 3 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 0     | TMR2EN   | 0x0 | rw   | Timer 2 clock enable<br>0: Disabled<br>1: Enabled         |

#### 4.3.14 APB2 peripheral clock enable register (CRM\_APB2EN)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name     | Reset value | Type | Description                                                  |
|-----------|----------|-------------|------|--------------------------------------------------------------|
| Bit 31:30 | Reserved | 0x00        | resd | Kept at its default value.                                   |
| Bit 29    | ACCEN    | 0x0         | rw   | ACC clock enable<br>0: Disabled<br>1: Enabled                |
| Bit 28:21 | Reserved | 0x00        | resd | Kept at its default value.                                   |
| Bit 20    | I2SF5EN  | 0x0         | rw   | I <sup>2</sup> SF5 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 19    | Reserved | 0x0         | resd | Kept at its default value.                                   |
| Bit 18    | TMR11EN  | 0x0         | rw   | Timer11 clock enable<br>0: Disabled<br>1: Enabled            |
| Bit 17    | TMR10EN  | 0x0         | rw   | Timer10 clock enable<br>0: Disabled<br>1: Enabled            |
| Bit 16    | TMR9EN   | 0x0         | rw   | Timer9 clock enable                                          |

|          |          |     |      |                                                          |
|----------|----------|-----|------|----------------------------------------------------------|
|          |          |     |      | 0: Disabled<br>1: Enabled                                |
| Bit 15   | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 14   | SCFGEN   | 0x0 | rw   | SCFG clock enable<br>0: Disabled<br>1: Enabled           |
| Bit 13   | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 12   | SPI1EN   | 0x0 | rw   | SPI1 clock enable<br>0: Disabled<br>1: Enabled           |
| Bit 11:9 | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 8    | ADC1EN   | 0x0 | rw   | ADC1 interface clock enable<br>0: Disabled<br>1: Enabled |
| Bit 7:6  | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 5    | USART6EN | 0x0 | rw   | USART6 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 4    | USART1EN | 0x0 | rw   | USART1 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 3:1  | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 0    | TMR1EN   | 0x0 | rw   | TMR1 clock enable<br>0: Disabled<br>1: Enabled           |

#### 4.3.15 AHB peripheral clock enable in low-power mode register 1 (CRM\_AHBLPEN1)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name      | Reset value | Type | Description                                                       |
|-----------|-----------|-------------|------|-------------------------------------------------------------------|
| Bit 31:30 | Reserved  | 0x1         | resd | Kept at its default value.                                        |
| Bit 29    | OTGHSLPEN | 0x1         | rw   | OTGHS clock enable in Sleep mode<br>0: Disabled<br>1: Enabled     |
| Bit 28:25 | Reserved  | 0x00        | resd | Kept at its default value.                                        |
| Bit 24    | DMA2LPEN  | 0x1         | rw   | DMA2 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled      |
| Bit 23    | Reserved  | 0x0         | resd | Kept at its default value.                                        |
| Bit 22    | DMA1LPEN  | 0x1         | rw   | DMA1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled      |
| Bit 21:17 | Reserved  | 0x00        | resd | Kept at its default value.                                        |
| Bit 16    | SRAMLPEN  | 0x1         | rw   | SRAM clock enable in Sleep mode<br>0: Disabled<br>1: Enabled      |
| Bit 15    | FLASHLPEN | 0x1         | rw   | FLASH clock enable in Sleep mode<br>0: Disabled<br>1: Enabled     |
| Bit 14:13 | Reserved  | 0x0         | resd | Kept at its default value.                                        |
| Bit 12    | CRCLPEN   | 0x1         | rw   | CRC clock enable in Sleep mode<br>0: Disabled<br>1: Enabled       |
| Bit 11:6  | Reserved  | 0x0         | resd | Kept at its default value.                                        |
| Bit 5     | GPIOFLPEN | 0x1         | rw   | IO port F clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 4     | Reserved  | 0x0         | resd | Kept at its default value.                                        |
| Bit 3     | GPIODLPEN | 0x1         | rw   | IO port D clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 2     | GPIOCLPEN | 0x1         | rw   | IO port C clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 1     | GPIOBLPEN | 0x1         | rw   | IO port B clock enable in Sleep mode                              |

|       |           |     |    |                                                                   |
|-------|-----------|-----|----|-------------------------------------------------------------------|
|       |           |     |    | 0: Disabled<br>1: Enabled                                         |
| Bit 0 | GPIOALPEN | 0x1 | rw | IO port A clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
|       |           |     |    |                                                                   |

#### 4.3.16 AHB peripheral clock enable in low-power mode register 2 (CRM\_AHBLPEN2)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name       | Reset value | Type | Description                                                    |
|----------|------------|-------------|------|----------------------------------------------------------------|
| Bit 31:8 | Reserved   | 0x000000    | resd | Kept at its default value.                                     |
| Bit 7    | OTGFS1LPEN | 0x1         | rw   | OTGFS1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 6:0  | Reserved   | 0x00        | resd | Kept at its default value.                                     |

#### 4.3.17 AHB peripheral clock enable in low-power mode register 3 (CRM\_AHBLPEN3)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name      | Reset value | Type | Description                                                   |
|----------|-----------|-------------|------|---------------------------------------------------------------|
| Bit 31:2 | Reserved  | 0x00000000  | resd | Kept at its default value.                                    |
| Bit 1    | QSPI1LPEN | 0x1         | rw   | QSPI1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 0    | Reserved  | 0x0         | resd | Kept at its default value.                                    |

#### 4.3.18 APB1 peripheral clock enable in low-power mode register (CRM\_APB1LPEN)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name       | Reset value | Type | Description                                                               |
|-----------|------------|-------------|------|---------------------------------------------------------------------------|
| Bit 31    | UART8LPEN  | 0x1         | rw   | UART8 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled             |
| Bit 30    | UART7LPEN  | 0x1         | rw   | UART7 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled             |
| Bit 29    | Reserved   | 0x0         | resd | Kept at its default value.                                                |
| Bit 28    | PWCLPEN    | 0x1         | rw   | Power interface clock enable in Sleep mode<br>0: Disabled<br>1: Enabled   |
| Bit 27:26 | Reserved   | 0x0         | resd | Kept at its default value.                                                |
| Bit 25    | CAN1LPEN   | 0x1         | rw   | CAN1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled              |
| Bit 24    | Reserved   | 0x0         | resd | Kept at its default value.                                                |
| Bit 23    | I2C3LPEN   | 0x1         | rw   | I <sup>2</sup> C3 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 22    | I2C2LPEN   | 0x1         | rw   | I <sup>2</sup> C2 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 21    | I2C1LPEN   | 0x1         | rw   | I <sup>2</sup> C1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 20    | USART5LPEN | 0x1         | rw   | USART5 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled            |
| Bit 19    | USART4LPEN | 0x1         | rw   | USART4 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled            |

|           |            |     |      |                                                                         |
|-----------|------------|-----|------|-------------------------------------------------------------------------|
| Bit 18    | USART3LPEN | 0x1 | rw   | USART3 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled          |
| Bit 17    | USART2LPEN | 0x1 | rw   | USART2 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled          |
| Bit 16    | Reserved   | 0x0 | resd | Kept at its default value.                                              |
| Bit 15    | SPI3LPEN   | 0x1 | rw   | SPI3 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled            |
| Bit 14    | SPI2LPEN   | 0x1 | rw   | SPI2 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled            |
| Bit 13:12 | Reserved   | 0x0 | resd | Kept at its default value.                                              |
| Bit 11    | WWDTLPEN   | 0x1 | rw   | Window watchdog clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 10:9  | Reserved   | 0x0 | resd | Kept at its default value.                                              |
| Bit 8     | TMR14LPEN  | 0x1 | rw   | Timer14 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 7     | TMR13LPEN  | 0x1 | rw   | Timer13 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 6     | Reserved   | 0x0 | resd | Kept at its default value.                                              |
| Bit 5     | TMR7LPEN   | 0x1 | rw   | Timer 7 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 4     | TMR6LPEN   | 0x1 | rw   | Timer 6 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 3     | Reserved   | 0x0 | resd | Kept at its default value.                                              |
| Bit 2     | TMR4LPEN   | 0x1 | rw   | Timer 4 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 1     | TMR3LPEN   | 0x1 | rw   | Timer 3 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 0     | TMR2LPEN   | 0x1 | rw   | Timer 2 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |

#### 4.3.19 APB2 peripheral clock enable in low-power mode register (CRM\_APB2LPEN)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name      | Reset value | Type | Description                                                     |
|-----------|-----------|-------------|------|-----------------------------------------------------------------|
| Bit 31:30 | Reserved  | 0x2         | resd | Kept at its default value.                                      |
| Bit 29    | ACCLPEN   | 0x1         | rw   | ACC clock enable in Sleep mode<br>0: Disabled<br>1: Enabled     |
| Bit 28:21 | Reserved  | 0x00        | resd | Kept at its default value.                                      |
| Bit 20    | I2SF5LPEN | 0x1         | rw   | I2SF5 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled   |
| Bit 19    | Reserved  | 0x0         | resd | Kept at its default value.                                      |
| Bit 18    | TMR11LPEN | 0x1         | rw   | Timer11 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 17    | TMR10LPEN | 0x1         | rw   | Timer10 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 16    | TMR9LPEN  | 0x1         | rw   | Timer9 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled  |
| Bit 15    | Reserved  | 0x0         | resd | Kept at its default value.                                      |

|          |            |     |      |                                                                        |
|----------|------------|-----|------|------------------------------------------------------------------------|
| Bit 14   | SCFGLPEN   | 0x1 | rw   | SCFG clock enable in Sleep mode<br>0: Disabled<br>1: Enabled           |
| Bit 13   | Reserved   | 0x0 | resd | Kept at its default value.                                             |
| Bit 12   | SPI1LPEN   | 0x1 | rw   | SPI1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled           |
| Bit 11:9 | Reserved   | 0x0 | resd | Kept at its default value.                                             |
| Bit 8    | ADC1LPEN   | 0x1 | rw   | ADC1 interface clock enable in Sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 7:6  | Reserved   | 0x0 | resd | Kept at its default value.                                             |
| Bit 5    | USART6LPEN | 0x1 | rw   | USART6 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 4    | USART1LPEN | 0x1 | rw   | USART1 clock enable in Sleep mode<br>0: Disabled<br>1: Enabled         |
| Bit 3:1  | Reserved   | 0x0 | resd | Kept at its default value.                                             |
| Bit 0    | TMR1LPEN   | 0x1 | rw   | TMR1 timer clock enable in Sleep mode<br>0: Disabled<br>1: Enabled     |

### 4.3.20 Battery powered domain control register (CRM\_BPDC)

This register is reset only by the battery powered domain reset.

Access: 0 to 3 wait states, accessible by words, half-words and bytes. Wait states are inserted in the case of consecutive accesses to this register.

Note: LEXTEN, LEXTBYPSS, ERTCSEL and ERTCEN bits of the CRM\_BPDC register are in the battery powered domain. As a result, these bits are write-protected after reset, and can only be modified by setting the BPWEN bit in the PWC\_CTRL register. These bits could be reset only by battery powered domain reset. Any internal or external reset does not affect these bits.

The maximum frequency of AHB is 120 MHz while accessing this register.

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                                                                        |
|-----------|-----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:17 | Reserved  | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                         |
| Bit 16    | BPDRST    | 0x0         | rw   | Battery powered domain software reset<br>0: Does not reset battery powered domain software<br>1: Reset battery powered domain software                                                                                             |
| Bit 15    | ERTCEN    | 0x0         | rw   | ERTC clock enable<br>This bit is set and cleared by software.<br>0: Disabled<br>1: Enabled                                                                                                                                         |
| Bit 14:10 | Reserved  | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                         |
| Bit 9:8   | ERTCSEL   | 0x0         | rw   | ERTC clock source selection<br>Once the ERTC clock source is selected, it cannot be changed until the BPDRST bit is reset.<br>00: None<br>01: LEXT<br>10: LICK<br>11: Divided HEXT (with the ERTC_DIV bit in the CRM_CFG register) |
| Bit 7:3   | Reserved  | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                         |
| Bit 2     | LEXTBYPSS | 0x0         | rw   | Low-speed external crystal bypass<br>0: Disabled<br>1: Enabled                                                                                                                                                                     |
| Bit 1     | LEXTSTBL  | 0x0         | ro   | External low-speed oscillator stable<br>This bit is set by hardware after the LEXT is ready.<br>0: LEXT is not ready<br>1: LEXT is ready                                                                                           |
| Bit 0     | LEXTEN    | 0x0         | rw   | External low-speed oscillator enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                  |

### 4.3.21 Control/status register (CRM\_CTRLSTS)

Reset flag can be cleared by power reset or by writing the RSTFC bit, while others are cleared by system reset.

Access: 0 to 3 wait states, accessible by words, half-words and bytes. Wait states are inserted in the case of consecutive accesses to this register.

Note: The maximum frequency of AHB is 120 MHz while accessing the LICKEN bit.

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                             |
|----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31   | LPRSTF   | 0x0         | ro   | Low-power reset flag<br>This bit is set by hardware and cleared by writing to the RSTFC bit with software.<br>0: No low-power reset occurs<br>1: Low-power reset occurs |
| Bit 30   | WWDTRSTF | 0x0         | ro   | WWDT reset flag<br>This bit is set by hardware and cleared by writing with software to the RSTFC bit.<br>0: No WWDT reset occurs<br>1: WWDT reset occurs                |
| Bit 29   | WDTRSTF  | 0x0         | ro   | WDT reset flag<br>This bit is set by hardware and cleared by writing to the RSTFC bit with software.<br>0: No WDT reset occurs<br>1: WDT reset occurs                   |
| Bit 28   | SWRSTF   | 0x0         | ro   | Software reset flag<br>This bit is set by hardware and cleared by writing to the RSTFC bit with software.<br>0: No software reset occurs<br>1: Software reset occurs    |
| Bit 27   | PORRSTF  | 0x1         | ro   | POR/LVR reset flag<br>This bit is set by hardware and cleared by writing to the RSTFC bit with software.<br>0: No POR/LVR reset occurs<br>1: POR/LVR reset occurs       |
| Bit 26   | NRSTF    | 0x1         | ro   | NRST reset flag<br>This bit is set by hardware and cleared by writing to the RSTFC bit with software.<br>0: No NRST reset occurs<br>1: NRST reset occurs                |
| Bit 25   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                              |
| Bit 24   | RSTFC    | 0x0         | rw   | Reset flag clear<br>This bit is cleared by writing "1" with software.<br>0: No effect<br>1: Clear reset flag                                                            |
| Bit 23:2 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                              |
| Bit 1    | LICKSTBL | 0x0         | ro   | LICK stable<br>0: LICK is not ready<br>1: LICK is ready                                                                                                                 |
| Bit 0    | LICKEN   | 0x0         | rw   | LICK enable<br>0: Disabled<br>1: Enabled                                                                                                                                |

### 4.3.22 OTGHS control register (CRM\_OTGHS)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit      | Name            | Reset value | Type | Description                                                   |
|----------|-----------------|-------------|------|---------------------------------------------------------------|
| Bit 31:5 | Reserved        | 0x0         | resd | Kept at its default value.                                    |
| Bit 4    | USBHS_PHY12_SEL | 0x0         | rw   | USBHS PHY 12M clock source select<br>0: HEXT/1<br>1: Reserved |
| Bit 3:0  | Reserved        | 0x0         | resd | Kept at its default value.                                    |

### 4.3.23 Additional register 1 (CRM\_MISC1)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                              |
|-----------|--------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:28 | CLKOUTDIV2   | 0x0         | rw   | Clock output division2<br>0xxx: Clock output not divided<br>1000: Clock output divided by 2<br>1001: Clock output divided by 4<br>1010: Clock output divided by 8<br>1011: Clock output divided by 16<br>1100: Clock output divided by 64<br>1101: Clock output divided by 128<br>1110: Clock output divided by 256<br>1111: Clock output divided by 512 |
| Bit 27:20 | Reserved     | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 19:16 | CLKOUT_SEL2  | 0xF         | rw   | Clock output sel2<br>0000: USBFS 48M clock output<br>0001: ADC clock output<br>0010: internal RC oscillator clock (HICK) output frequency divider<br>0011: LICK clock output<br>0100: LEXT clock output<br>0101~1111: Reserved                                                                                                                           |
| Bit 15    | Reserved     | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 14    | HICK_TO_SCLK | 0x0         | rw   | HICK as system clock frequency select<br>When the HICK is selected as system clock by setting the SCLKSEL bit, the frequency of SCLK is:<br>0: Fixed 8 MHz, that is, HICK/6<br>1: 48 MHz or 8 MHz, depending on the HICKDIV                                                                                                                              |
| Bit 13    | Reserved     | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 12    | HICKDIV      | 0x0         | rw   | HICK 6 divider selection<br>This bit is used to select HICK or HICK/6. If the HICK/6 is selected, the system clock is 8 MHz; otherwise, the system clock is 48 MHz.<br>0: HICK/6<br>1: HICK<br>Note: When HICK is used as PLL clock source, do not modify the HICKDIV while PLL is enabled.                                                              |
| Bit 11:8  | Reserved     | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 7:0   | HICKCAL_KEY  | 0x00        | rw   | HICK calibration key<br>The HICKCAL[7:0] can be written only when this field is set to 0x5A.                                                                                                                                                                                                                                                             |

### 4.3.24 Additional register 2 (CRM\_MISC2)

Access: 0 wait state, accessible by words, half-words and bytes

| Bit       | Name             | Reset value | Type | Description                                                                                                                                           |
|-----------|------------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:30 | Reserved         | 0x1         | resd | Fixed to 0x1. Do not modify.                                                                                                                          |
| Bit 29:22 | Reserved         | 0x0         | resd | Kept at its default value.                                                                                                                            |
| Bit 21:19 | HEXT_TO_SCLK_DIV | 0x00        | rw   | HEXT as system clock frequency division<br>000: HEXT<br>001: HEXT/2<br>010: HEXT/4<br>011: HEXT/8<br>100: HEXT/16<br>101: HEXT/32<br>Others: Reserved |
| Bit 18:16 | HICK_TO_SCLK_DIV | 0x00        | rw   | HICK as system clock frequency division<br>000: HICK<br>001: HICK/2<br>010: HICK/4<br>011: HICK/8<br>100: HICK/16<br>Others: Reserved                 |
| Bit 15:11 | Reserved         | 0x0         | resd | Kept at its default value.                                                                                                                            |
| Bit 10    | PLL_USB48_SEL    | 0x0         | rw   | USBFS 48M clock source selection                                                                                                                      |

|         |              |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|--------------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |              |     |      | 0:PLL<br>1:HICK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 9:6 | Reserved     | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 5:4 | AUTO_STEP_EN | 0x0 | rw   | <p>Auto step-by-step system clock switch enable<br/>When the system clock source is switched from others to the PLL or when the AHB prescaler is changed from large to small (system frequency is from small to large), it is recommended to enable the auto step-by-step system clock switch if the operational target is larger than 108 MHz.</p> <p>Once it is enabled, the AHB bus is halted by hardware till the completion of the switch. During this switch period, the DMA remain working, and the interrupt events are recorded and then handled by NVIC when the AHB bus resumes.</p> <p>00: Disabled<br/>01: Reserved<br/>10: Reserved<br/>11: Enabled. When AHBDIV or SCLKSEL bits is modified, the auto step-by-step system clock switch is activated automatically.</p> |
| Bit 3:0 | Reserved     | 0xD | resd | It is fixed to 0xD. Do not change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# 5 Flash memory controller (FLASH)

## 5.1 FLASH introduction

Flash memory is divided into three parts: main Flash memory, information block and Flash memory registers.

- Main Flash memory is up to 256 KB.
- Information block consists of 20 KB bootloader and the user system data area. The bootloader uses USART1, USART2, I<sup>2</sup>C, SPI, CAN or USB for ISP programming.

Main Flash memory contains bank 1 (256 KB), including 128 sectors, 2 KB per sector.

Table 5-1 Flash memory architecture (256 KB)

| Bank                  | Name                   | Address range             |
|-----------------------|------------------------|---------------------------|
| Main memory<br>256 KB | Sector 0               | 0x0800 0000 – 0x0800 07FF |
|                       | Sector 1               | 0x0800 0800 – 0x0800 0FFF |
|                       | Sector 2               | 0x0800 1000 – 0x0800 17FF |
|                       | ...                    | ...                       |
|                       | Sector 127             | 0x0803 F800 – 0x0803 FFFF |
| Information block     | 20 KB bootloader       | 0x1FFF A400 – 0x1FFF F3FF |
|                       | 512 B user system data | 0x1FFF F800 – 0x1FFF F9FF |

Main Flash memory contains bank 1 (128 KB), including 128 sectors, 1 KB per sector.

Table 5-2 Flash memory architecture (128 KB)

| Bank                  | Name                   | Address range             |
|-----------------------|------------------------|---------------------------|
| Main memory<br>128 KB | Sector 0               | 0x0800 0000 – 0x0800 03FF |
|                       | Sector 1               | 0x0800 0400 – 0x0800 07FF |
|                       | Sector 2               | 0x0800 0800 – 0x0800 0BFF |
|                       | ...                    | ...                       |
|                       | Sector 127             | 0x0801 FC00 – 0x0801 FFFF |
| Information block     | 20 KB bootloader       | 0x1FFF A400 – 0x1FFF F3FF |
|                       | 512 B user system data | 0x1FFF F800 – 0x1FFF F9FF |

### User system data area

The system data will be read from the information block of Flash memory whenever a system reset occurs, and is saved in the user system data register (FLASH\_USD) and erase/programming protection status register (FLASH\_EPPS).

Each system data occupies two bytes, where the low bytes corresponds to the contents in the system data area, and the high bytes represent the inverse code that is used to verify the correctness of the selected bit. When the high byte is not equal to the inverse code of the low byte (except when both high and low byte are all 0xFF), the system data loader will issue a system data error flag (USDERR) and the corresponding system data and their inverse codes are forced 0xFF.

Note: The update of the contents in the user system data area becomes effective only after a system reset.

Table 5-3 User system data area

| Address     | Bit     | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x1FFF_F800 | [7:0]   | <b>FAP[7:0]:</b> Flash memory access protection (Access protection enable/disable result is stored in the FLASH_USD [1] and [26])<br>0xA5: Flash access protection disabled<br>0xCC: High-level Flash access protection enabled<br>Others: Low-level Flash access protection enabled                                                                                                                                                    |
|             | [15:8]  | <b>nFAP[7:0]:</b> Inverse code of FAP[7:0]<br><b>SSB[7:0]:</b> System setting byte (stored in the FLASH_USD[9:2])                                                                                                                                                                                                                                                                                                                       |
|             | [23:16] | <b>Bit 7 (nRAM_PRT_CHK)</b><br>0: Enable RAM parity check<br>1: Disable RAM parity check                                                                                                                                                                                                                                                                                                                                                |
|             |         | <b>Bit 6 (nSTDBY_WDT)</b><br>0: WDT stops counting while entering Standby mode<br>1: WDT does not stop counting while entering Standby mode                                                                                                                                                                                                                                                                                             |
|             |         | <b>Bit 5 (nDEPSLP_WDT)</b><br>0: WDT stops counting while entering Deepsleep mode<br>1: WDT does not stop counting while entering Deepsleep mode                                                                                                                                                                                                                                                                                        |
|             |         | <b>Bit 4 (nBOOT1)</b><br>nBOOT1: It defines boot mode together with BOOT0 pin.<br>When BOOT0 = 1:<br>0: Boot from SRAM<br>1: Boot from boot memory                                                                                                                                                                                                                                                                                      |
|             |         | <b>Bit 3</b><br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
|             |         | <b>Bit 2 (nSTDBY_RST)</b><br>0: Reset occurs when entering Standby mode<br>1: No reset occurs when entering Standby mode                                                                                                                                                                                                                                                                                                                |
|             |         | <b>Bit 1 (nDEPSLP_RST)</b><br>0: Reset occurs when entering Deepsleep mode<br>1: No reset occurs when entering Deepsleep mode                                                                                                                                                                                                                                                                                                           |
|             |         | <b>Bit 0 (nWDT_ATO_EN)</b><br>0: Watchdog is enabled<br>1: Watchdog is disabled                                                                                                                                                                                                                                                                                                                                                         |
|             | [31:24] | <b>nSSB[7:0]:</b> Inverse code of SSB[7:0]                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x1FFF_F804 | [7:0]   | <b>Data0[7:0]:</b> User data 0 (stored in the FLASH_USD[17:10])                                                                                                                                                                                                                                                                                                                                                                         |
|             | [15:8]  | <b>nData0[7:0]:</b> Inverse code of Data0[7:0]                                                                                                                                                                                                                                                                                                                                                                                          |
|             | [23:16] | <b>Data1[7:0]:</b> User data 1 (stored in the FLASH_USD[25:18])                                                                                                                                                                                                                                                                                                                                                                         |
|             | [31:24] | <b>nData1[7:0]:</b> Inverse code of Data1[7:0]                                                                                                                                                                                                                                                                                                                                                                                          |
|             | [7:0]   | <b>EPP0[7:0]:</b> Flash erase/write protection byte 0 (stored in the FLASH_EPPS[7:0])<br>This field is used to protect sector0~sector15 of the main Flash memory (256 KB) and sector0~sector31 of the main Flash memory (128 KB). Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled                                                                                 |
| 0x1FFF_F808 | [15:8]  | <b>nEPP0[7:0]:</b> Inverse code of EPP0[7:0]                                                                                                                                                                                                                                                                                                                                                                                            |
|             | [23:16] | <b>EPP1[7:0]:</b> Flash erase/write protection byte 1 (stored in the FLASH_EPPS[15:8])<br>This field is used to protect sector16~sector31 of the main Flash memory (256 KB) and sector32~sector63 of the main Flash memory (128 KB). Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled                                                                              |
|             | [31:24] | <b>nEPP1[7:0]:</b> Inverse code of EPP1[7:0]                                                                                                                                                                                                                                                                                                                                                                                            |
|             | [7:0]   | <b>EPP2[7:0]:</b> Flash erase/write protection byte 2 (stored in the FLASH_EPPS[23:16])<br>This field is used to protect sector32~sector47 of the main Flash memory (256 KB) and sector64~sector95 of the main Flash memory (128 KB). Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled                                                                             |
| 0x1FFF_F80C | [15:8]  | <b>nEPP2[7:0]:</b> Inverse code of EPP2[7:0]                                                                                                                                                                                                                                                                                                                                                                                            |
|             | [23:16] | <b>EPP3[7:0]:</b> Flash erase/write protection byte 3 (stored in the FLASH_EPPS[31:24])<br>Bit [6:0] is used to protect sector48~sector61 of the main Flash memory (256 KB) and sector 96~sector 123 of the main Flash memory (128 KB). Each bit takes care of 4 KB sectors.<br>Bit [7] is used to protect sector 62~sector 127 of the main Flash memory (256 KB) and sector124~sector127 of the main Flash memory (128 KB). Bit [7] is |

|                                 |         |                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |         | also used for the main Flash memory (256 KB/128 KB) extension area.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled                                                                                                                                                                                                                               |
|                                 | [31:24] | <b>nEPP3[7:0]:</b> Inverse code of EPP3[7:0]                                                                                                                                                                                                                                                                                                                                       |
| 0x1FFF_F810<br>~<br>0x1FFF_F830 | [31:0]  | Reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 0x1FFF_F834                     | [7:0]   | <b>QSPIKEY0[7:0]:</b> Quad SPI (QSPI) ciphertext access area encryption key byte 0<br>The situations for non-encryption includes:<br>QSPIKEYx and nQSPIKEYx are 0xFF (default erase status)<br>Write 0x00 to QSPIKEYx<br>Write 0xFF to QSPIKEYx<br>That is, {nQSPIKEYx, QSPIKEYx} are all 0xFFFF, 0xFF00, 0x00FF.<br>Among them, QSPIKEY0-QSPIKEY3 are the encrypted key of QSPI1. |
|                                 | [15:8]  | <b>nQSPIKEY0[7:0]:</b> Inverse code of QSPIKEY0[7:0]                                                                                                                                                                                                                                                                                                                               |
|                                 | [23:16] | <b>QSPIKEY1[7:0]:</b> Quad SPI (QSPI) ciphertext access area encryption key byte 1                                                                                                                                                                                                                                                                                                 |
|                                 | [31:24] | <b>nQSPIKEY1[7:0]:</b> Inverse code of QSPIKEY1[7:0]                                                                                                                                                                                                                                                                                                                               |
| 0x1FFF_F838                     | [7:0]   | <b>QSPIKEY2[7:0]:</b> Quad SPI (QSPI) ciphertext access area encryption key byte 2                                                                                                                                                                                                                                                                                                 |
|                                 | [15:8]  | <b>nQSPIKEY2[7:0]:</b> Inverse code of QSPIKEY2[7:0]                                                                                                                                                                                                                                                                                                                               |
|                                 | [23:16] | <b>QSPIKEY3[7:0]:</b> Quad SPI (QSPI) ciphertext access area encryption key byte 3                                                                                                                                                                                                                                                                                                 |
|                                 | [31:24] | <b>nQSPIKEY3[7:0]:</b> Inverse code of QSPIKEY3[7:0]                                                                                                                                                                                                                                                                                                                               |
| 0x1FFF_F83C<br>~<br>0x1FFF_F848 | [31:0]  | Reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 0x1FFF_F84C                     | [7:0]   | <b>Data2[7:0]:</b> User data 2                                                                                                                                                                                                                                                                                                                                                     |
|                                 | [15:8]  | <b>nData2[7:0]:</b> Inverse code of Data2[7:0]                                                                                                                                                                                                                                                                                                                                     |
|                                 | [23:16] | <b>Data3[7:0]:</b> User data 3                                                                                                                                                                                                                                                                                                                                                     |
|                                 | [31:24] | <b>nData3[7:0]:</b> Inverse code of Data3[7:0]                                                                                                                                                                                                                                                                                                                                     |
| ..                              | ..      | ..                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x1FFF_F9FC                     | [7:0]   | <b>Data218[7:0]:</b> User data 218                                                                                                                                                                                                                                                                                                                                                 |
|                                 | [15:8]  | <b>nData218[7:0]:</b> Inverse code of Data218[7:0]                                                                                                                                                                                                                                                                                                                                 |
|                                 | [23:16] | <b>Data219[7:0]:</b> User data 219                                                                                                                                                                                                                                                                                                                                                 |
|                                 | [31:24] | <b>nData219[7:0]:</b> Inverse code of Data219[7:0]                                                                                                                                                                                                                                                                                                                                 |

## 5.2 Flash memory operation

### 5.2.1 Unlock/lock

After reset, Flash memory is protected, by default. The FLASH\_CTRL register cannot be written. Write and erase operation can be performed only when the Flash memory is unlocked.

#### Unlock procedure:

Flash memory block can be unlocked by writing KEY1 (0x45670123) and KEY2 (0xCDEF89AB) to the FLASH\_UNLOCK register.

*Note: Writing an incorrect key sequence leads to a bus error and the Flash memory is also locked until the next reset.*

#### Lock procedure:

Flash memory block can be locked by setting the OPLK bit in the FLASH\_CTRL register.

### 5.2.2 Erase operation

Erase operation must be done before programming. Flash memory erase includes sector erase and mass erase.

#### Sector erase

Any sector in the Flash memory and the Flash memory extension area can be erased with sector erase function independently.

The following process is recommended:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming operation in progress;
- Write the sector to be erased in the FLASH\_ADDR register;
- Set the SECERS and ERSTR bits in the FLASH\_CTRL register to enable sector erase;
- Wait until the OBF bit in the FLASH\_STS register becomes “0”. Read the EPPERR and ODF bits in the FLASH\_STS register to verify the erased sectors.

*Note: When the boot memory is configured as the Flash memory extension area, performing sector-erase operation erases the entire Flash memory extension area.*

Figure 5-1 Flash memory sector erase process



### Mass erase

Mass erase function can be used to erase all the Flash memory.

The following process is recommended:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming

- operation in progress;
- Set the BANKERS and ERSTR bits in the FLASH\_CTRL register to enable mass erase;
- Wait until the OBF bit in the FLASH\_STS register becomes “0”. Read the EPPERR and ODF bits in the FLASH\_STS register to verify the erase result.

Note:

- 1) When the boot memory is configured as the Flash memory extension area, performing mass-erase operation erases automatically the entire Flash memory and its extension area.
- 2) Read access during erase operation halts the CPU and waits until the completion of erase.
- 3) Internal HICK must be enabled prior to erase operation.

Figure 5-2 Flash memory mass erase process



### 5.2.3 Programming operation

The Flash memory can be programmed with 32 bits, 16 bits or 8 bits at a time.

The following process is recommended:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming operation in progress;
- Set FPRGM=1 in the FLASH\_CTRL register, so that the Flash memory programming instructions can be received;
- Write the data (word/half-word/byte) to be programmed to the designated address;

- Wait until the OBF bit in the FLASH\_STS register becomes "0". Read the EPPERR, PRGMERR and ODF bits in the FLASH\_STS register to verify the programming result.

Note:

- When the address to be written is not erased in advance, the programming operation is not executed unless the data to be written is all 0. In this case, a programming error is reported by the PRGMERR bit in the FLASH\_STS register.
- CPU halts during programming and waits until the completion of programming.
- Internal HICK must be enabled prior to programming.

Figure 5-3 Flash memory programming process



## 5.2.4 Read operation

Flash memory can be accessed through AHB bus of the CPU.

## 5.3 Main Flash memory extension area

Boot memory can also be programmed as the extension area of the main Flash memory to store user-application code. When used as main Flash memory extension area, it behaves like the main Flash memory, including read, unlock, erase and programming operations.

## 5.4 User system data area operation

### 5.4.1 Unlock/lock

After reset, user system data area is protected, by default. Write and erase operations can be performed only after the Flash memory is unlocked before the unlock operation for the user system data area.

#### Unlock procedure:

Flash memory can be unlocked by writing KEY1 (0x45670123) and KEY2 (0xCDEF89AB) to the FLASH\_UNLOCK register.

When KEY1 (0x45670123) and KEY2 (0xCDEF89AB) are written to the FLASH\_USD\_UNLOCK register, the USDULKS bit in the FLASH\_CTRL register will be automatically set by hardware, indicating that it supports write/erase operation to the user system data area.

*Note: Writing an incorrect key sequence leads to bus error and the Flash memory is also locked until the next reset.*

#### Lock procedure:

User system data area is locked by clearing the USDULKS bit in the FLASH\_CTRL register.

### 5.4.2 Erase operation

Erase operation must be done before programming. User system data area can be erased independently.

The following process is recommended:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming operation in progress;
- Set the USDRS and ERSTR bits in the FLASH\_CTRL register to enable erase operation;
- Wait until the OBF bit in the FLASH\_STS register becomes "0". Read the ODF bit in the FLASH\_STS register to verify the erase result.

*Note:*

- 1) *Read operation to the Flash memory during programming halts CPU and waits until the completion of erase.*
- 2) *The internal HICK must be enabled prior to erase operation.*

Figure 5-4 System data area erase process



### 5.4.3 Programming operation

The user system data area can be programmed with 16 bits or 32 bits at a time.

The following process is recommended:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming operation in progress;
- Set USDPRGM=1 in the FLASH\_CTRL register, so that the programming instructions for the user system data area can be received;
- Write the data (word/half-word) to be programmed to the designated address;
- Wait until the OBF bit in the FLASH\_STS register becomes "0". Read the PRGMERR and ODF bits in the FLASH\_STS register to verify the programming result.

Note:

- 1) CPU halts during programming and waits until the completion of programming.
- 2) The internal HICK must be enabled prior to erase operation.

Figure 5-5 System data area programming process



#### 5.4.4 Read operation

User system data area can be accessed through AHB bus of the CPU.

### 5.5 Flash memory protection

Flash memory protection includes access and erase/program protection.

#### 5.5.1 Access protection

Flash memory access protection is divided into two parts: high-level and low level.

Once enabled, only the Flash program is allowed to read Flash memory data. This read operation is not permitted in debug mode or by booting from non-Flash memory.

##### Low-level access protection

When the contents in the nFAP and FAP are different from 0x5A and 0xA5, and 0x33 and 0xCC, the low-level Flash memory access protection is enabled after a system reset.

When the Flash access is protected, the user can re-erase the system data area, and unlock Flash access protection (switching from low-level protection to unprotected state will trigger mass erase on the Flash memory and its extension area automatically) by writing 0xA5 to FAP byte, and then perform a system reset. Subsequently, the system data loader will be reloaded with system data and updated with Flash memory access protection disable state (FAP byte).

### High-level access protection

When the content in the nFAP is equal to 0x33, and the content in the FAP byte is equal to 0xCC, the high-level Flash memory access protection is enabled after a system reset.

Once enabled, it cannot be unlocked, and it is not permissible for users to re-erase and write the system data area.

**Note:**

- 1) *The main Flash memory extension area can also be protected.*
- 2) *If the access protection bit is set in debug mode, then the debug mode has to be cleared by POR instead of system reset in order to resume access to Flash memory data.*

Table 5-4 shows Flash memory access limits when Flash access protection is enabled.

Table 5-4 Flash memory access limit

| Block                 | Protection level      | Access limits                                  |            |                       |                             |             |       |
|-----------------------|-----------------------|------------------------------------------------|------------|-----------------------|-----------------------------|-------------|-------|
|                       |                       | In debug mode or boot from SRAM or boot memory |            |                       | Boot from main Flash memory |             |       |
|                       |                       | Read                                           | Write      | Erase                 | Read                        | Write       | Erase |
| Main Flash memory     | Low-level protection  | Not allowed                                    |            | Not allowed<br>(1)(2) | Accessible                  |             |       |
|                       | High-level protection | None (3)                                       |            |                       | Accessible                  |             |       |
| User system data area | Low-level protection  | Not allowed                                    | Accessible |                       | Accessible                  |             |       |
|                       | High-level protection | None (3)                                       |            |                       | Accessible                  | Not allowed |       |

- (1) Main Flash memory is cleared automatically by hardware only when the access protection is disabled;
- (2) Only sector erase is forbidden, and mass erase is not affected;
- (3) When the high-level access protection is enabled, the system automatically boots from the main Flash memory.

### 5.5.2 Erase/program protection

Erase/program protection is performed on the basis of 4 KB. This is used to protect the contents in the Flash memory against inadvertent operation when the program crash occurs.

Erase/program operation is not permitted under one of the following events, and the EPPERR bit is set accordingly when:

- Erasing/programming the pages (in Flash memory and its extension area) where erase/program protection is enabled;
- Performing mass erase on the sectors and main Flash memory extension area where erase/program protection enabled;
- When the Flash access protection is enabled, the sector0~sector1 in the 256 KB main Flash memory and sector0~sector3 in the 128 KB Flash memory will be protected against sector erase/program automatically;
- When the Flash access protection is enabled, the main Flash memory is protected against sector erase and programming operation when the main Flash memory and its extension area are in debug mode or when it boots from non-main Flash memory.

## 5.6 Read access

To increase system clock frequency, program the number of wait states to access the Flash memory through the WTCYC bit in the FLASH\_PSR register.

The Flash read times can be decreased through the PFT\_EN, PFT\_EN2 and PFT\_LAT\_DIS bits in the FLASH\_PSR register.

## 5.7 Special functions

### 5.7.1 Security library settings

Security library is a defined area protected by a code in the main memory. This area is only executable but cannot be written or deleted unless a correct code is keyed in. Security library includes instruction security library (cannot be read) and data security library (can be read).

#### Advantages of security library:

Security library is protected by codes so that solution providers can program core algorithm into this area;

Security library cannot be read or deleted (including ISP/IAP/SWD) but only executed unless the code defined by the solution provider is keyed in;

The rest of the area can be used for secondary development by solution providers;

Solution providers can sell core algorithm with security library function and do not have to develop full solutions for every customer.

Security library helps prevent from deliberate damage or changing terminal application codes.

#### Note:

*Security library code must be programmed by sector, with its start address aligned with the main memory address;*

*Only CPU instruction is allowed to read instruction security library;*

*In an attempt of writing or erasing the security library code, a warning message will be issued by EPPERR=1 in the FLASH\_STS register;*

*Executing mass erase in the main memory will not erase the security library.*

By default, security library setting register is unreadable and write protected. To enable write access to this register, security library should be unlocked first, by writing 0xA35F6D24 to the SLIB\_UNLOCK register, and checking the SLIB\_ULKF bit in the SLIB\_MISC\_STS register to verify if it is unlocked successfully, and then writing the programmed value to the security library setting register.

The steps to enable security library are as follows:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming operation in progress;
- Write 0xA35F6D24 to the SLIB\_UNLOCK register to unlock the security library;
- Check the SLIB\_ULKF bit in the SLIB\_MISC\_STS register to verify that it is unlocked successfully;
- If the security library is set in the main Flash memory, set the sectors to be protected in the SLIB\_SET\_RANGE register (including the addresses of instruction/data security library); if the security library is set in the main Flash memory extension area, set the EM\_SLIB\_SET register;
- Wait until the OBF bit becomes “0”;
- Set the security library password in the SLIB\_SET\_PWD register;
- Wait until the OBF bit becomes “0”;
- Program the code to be saved in security library;
- Perform a system reset, and then reload security library setting word;
- Read the SLIB\_STS0/STS1 register to verify the security library settings.

#### Note:

*The main Flash memory and its extension area cannot be set as security library at the same time.*

*Security library should be enabled when the Flash access protection is not activated.*

The steps to unlock security library are as follows:

- Write the previously set security library password to the SLIB\_PWD\_CLR register;
- Wait until the OBF bit becomes “0”;

- Perform a system reset, and then reload security library setting word;
- Read the SLIB\_STS0 register to verify that if the security library is unlocked successfully.

*Note: Disabling the security library will automatically perform mass erase for the main Flash memory and its extension, as well as the security library setting block.*

### 5.7.2 Boot memory used as Flash memory extension

There is only one chance for users to program the boot memory as the main Flash extension area, which will have the same features as those of Flash memory after successful configuration as follows:

- Read bit [0] in the SLIB\_STS0 register to get the current mode of the boot memory;
- Write 0xA35F6D24 to the SLIB\_UNLOCK register to unlock the current mode of boot memory;
- Write non-0xFF to bit [7:0] in the BTM\_MODE\_SET register;
- Wait until the OBF bit becomes “0”;
- Perform a system reset, and then reload setting words;
- Read the SLIB\_STS0 register to verify the settings.

*Note:*

*The above-mentioned process must be performed when the Flash memory access protection not activated.*

*Once the boot memory is used as Flash memory extension area, the “boot from boot memory” is forced to “boot from main Flash memory”.*

### 5.7.3 CRC verify

The optional CRC check for security library code or user code is performed on a sector level.

- Generator polynomial: 0x4C11DB7,
- That is,  $X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$
- CRC initial value: 0x00000000

CRC verify procedure is as follows:

- Check the OBF bit in the FLASH\_STS register to confirm that there is no other programming operation in progress;
- Program the start address of the code to be CRC check in the FLASH\_CRC\_ADDR register;
- Program the code count (in terms of sectors) to be CRC check through the bit [15:0] in the FLASH\_CRC\_CTRL register;
- Enable CRC verify by setting the bit [16] in the FLASH\_CRC\_CTRL register;
- Wait until the OBF bit becomes “0”;
- Read the FLASH\_CRC\_CHK register to verify the result.

*Note:*

*The values of FLASH\_CRC\_ADDR register must be aligned with the start address of the sector.*

*CRC verify must not cross the main Flash memory and its extension area.*

## 5.8 FLASH registers

These peripheral registers must be accessed by words (32 bits).

Table 5-5 Flash memory register map and reset value

| Register         | Offset | Reset value |
|------------------|--------|-------------|
| FLASH_PSR        | 0x00   | 0x0000 01F0 |
| FLASH_UNLOCK     | 0x04   | 0xFFFF XXXX |
| FLASH_USD_UNLOCK | 0x08   | 0xFFFF XXXX |
| FLASH_STS        | 0x0C   | 0x0000 0000 |
| FLASH_CTRL       | 0x10   | 0x0002 0080 |
| FLASH_ADDR       | 0x14   | 0x0000 0000 |
| FLASH_USD        | 0x1C   | 0x03FF FFFC |

|                |       |             |
|----------------|-------|-------------|
| FLASH_EPPS     | 0x20  | 0xFFFF FFFF |
| SLIB_STS0      | 0x74  | 0x00FF 0000 |
| SLIB_STS1      | 0x78  | 0xFFFF FFFF |
| SLIB_PWD_CLR   | 0x7C  | 0xFFFF FFFF |
| SLIB_MISC_STS  | 0x80  | 0x0000 0000 |
| FLASH_CRC_ADDR | 0x84  | 0x0000 0000 |
| FLASH_CRC_CTRL | 0x88  | 0x0000 0000 |
| FLASH_CRC_CHK  | 0x8C  | 0x0000 0000 |
| SLIB_SET_PWD   | 0x160 | 0x0000 0000 |
| SLIB_SET_RANGE | 0x164 | 0x0000 0000 |
| EM_SLIB_SET    | 0x168 | 0x0000 0000 |
| BTM_MODE_SET   | 0x16C | 0x0000 0000 |
| SLIB_UNLOCK    | 0x170 | 0x0000 0000 |

### 5.8.1 Flash performance select register (FLASH\_PSR)

| Bit      | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|-------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:9 | Reserved    | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 8    | PFT_LAT_DIS | 1           | rw   | Prefetch latency disable<br>0: Prefetch buffer latency enabled, one system clock cycle for buffer access<br>1: Prefetch buffer latency disabled, 0-wait state for buffer access<br>It is recommended to set this bit to 1 and do not change.                                                                                                                                                                                                                                                                                   |
| Bit 7    | PFT_ENF2    | 1           | ro   | Prefetch enabled flag2<br>When this bit is set, it indicates that the prefetch buffer 2 is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 6    | PFT_EN2     | 1           | rw   | Prefetch enable2<br>0: Prefetch buffer 2 is disabled<br>1: Prefetch buffer 2 is enabled<br>It is recommended to set this bit to 1 and do not change.                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 5    | PFT_ENF     | 1           | ro   | Prefetch enabled flag<br>When this bit is set, it indicates that the prefetch buffer is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 4    | PFT_EN      | 1           | rw   | Prefetch enable<br>0: Prefetch buffer is disabled<br>1: Prefetch buffer is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3    | Reserved    | 0           | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 2:0  | WTCYC       | 0x0         | rw   | Wait cycle<br>The wait states depend on the size of the system clock, and they are in terms of system clocks.<br>000: Zero wait state, 0 MHz < system clock ≤ 32 MHz<br>001: One wait state, 32 MHz < system clock ≤ 64 MHz<br>010: Two wait states, 64 MHz < system clock ≤ 96 MHz<br>011: Three wait states, 96 MHz < system clock ≤ 128 MHz<br>100: Four wait states, 128 MHz < system clock ≤ 160 MHz<br>101: Five wait states, 160 MHz < system clock ≤ 192 MHz<br>110: Six wait states, 192 MHz < system clock ≤ 216 MHz |

### 5.8.2 Flash unlock register (FLASH\_UNLOCK)

| Bit      | Name  | Reset value   | Type | Description                                                                         |
|----------|-------|---------------|------|-------------------------------------------------------------------------------------|
| Bit 31:0 | UKVAL | 0XXXX XXXX wo |      | Unlock key value<br>This is used to unlock the Flash memory and its extension area. |

Note: All these bits are write-only, and return 0 when being read.

### 5.8.3 Flash user system data unlock register (FLASH\_USD\_UNLOCK)

| Bit      | Name      | Reset value   | Type | Description                       |
|----------|-----------|---------------|------|-----------------------------------|
| Bit 31:0 | USD_UKVAL | 0XXXX XXXX wo |      | User system data unlock key value |

Note: All these bits are write-only, and return 0 when being read.

### 5.8.4 Flash status register (FLASH\_STS)

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                               |
|----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:6 | Reserved | 0x00000000  | resd | Kept at its default value.                                                                                                                                                |
| Bit 5    | ODF      | 0           | rwc1 | Operation done flag<br>This bit is set by hardware when Flash memory operations (program/erase) are completed. It is cleared by writing "1".                              |
| Bit 4    | EPPERR   | 0           | rwc1 | Erase/program protection error<br>This bit is set by hardware when erasing or programming the erase/program-protected Flash memory address. It is cleared by writing "1". |
| Bit 3    | Reserved | 0           | resd | Kept at its default value.                                                                                                                                                |
| Bit 2    | PRGMERR  | 0           | rwc1 | Program error<br>When the programming address is not in erase state, this bit is set by hardware. It is cleared by writing "1".                                           |
| Bit 1    | Reserved | 0           | resd | Kept at its default value.                                                                                                                                                |
| Bit 0    | OBF      | 0           | ro   | Operation busy flag<br>When this bit is set, it indicates that Flash memory operations are in progress. It is cleared when operations are completed.                      |

### 5.8.5 Flash control register (FLASH\_CTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                  |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:13  | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                   |
| Bit 12     | ODFIE    | 0           | rw   | Operation done flag interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                            |
| Bit 11,8,3 | Reserved | 0           | resd | Kept at its default value.                                                                                                                                                                                                                                                   |
| Bit 10     | ERRIE    | 0           | rw   | Error interrupt enable<br>This bit enables EPPERR or PRGMERR interrupt.<br>0: Disabled<br>1: Enabled                                                                                                                                                                         |
| Bit 9      | USDULKS  | 0           | rw   | User system data unlock success<br>This bit is set by hardware when the user system data is unlocked properly, indicating that erase/program operation to the user system data is allowed. This bit is cleared by writing "0", which will re-lock the user system data area. |
| Bit 7      | OPLK     | 1           | rw   | Operation lock<br>This bit is set by default, indicating that Flash memory is protected against operations. This bit is cleared by hardware after unlock, indicating that erase/program operation to Flash memory is allowed. Writing "1" can relock the Flash memory.       |
| Bit 6      | ERSTR    | 0           | rw   | Erase start<br>An erase operation is triggered when this bit is set by software. This bit is cleared by hardware after the completion of the erase operation.                                                                                                                |
| Bit 5      | USDERS   | 0           | rw   | User system data erase<br>It indicates the user system data erase operation.                                                                                                                                                                                                 |
| Bit 4      | USDPRGM  | 0           | rw   | User system data program<br>It indicates the user system data programming operation.                                                                                                                                                                                         |
| Bit 2      | BANKERS  | 0           | rw   | Bank erase<br>It indicates bank erase operation.                                                                                                                                                                                                                             |
| Bit 1      | SECERS   | 0           | rw   | Sector erase<br>It indicates sector erase operation.                                                                                                                                                                                                                         |
| Bit 0      | FPRGM    | 0           | rw   | Flash program<br>It indicates Flash programming operation.                                                                                                                                                                                                                   |

### 5.8.6 Flash address register (FLASH\_ADDR)

| Bit      | Name | Reset value | Type | Description                                                      |
|----------|------|-------------|------|------------------------------------------------------------------|
| Bit 31:0 | FA   | 0x0000 0000 | wo   | Flash address<br>Select the address of the sectors to be erased. |

### 5.8.7 User system data register (FLASH\_USD)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:27 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                         |
|           |          |             |      | Flash access protection high level<br>The status of the Flash access protection is determined by bit [26] and bit [1].                                                                                                             |
| Bit 26    | FAP_HL   | 0           | ro   | 00: Flash access protection disabled, and FAP=0xA5<br>01: Low-level Flash access protection enabled, and FAP=non-0xCC and non-0xA5<br>10: Reserved<br>11: High-level Flash access protection enabled, and FAP=0xCC                 |
| Bit 25:18 | USER_D1  | 0xFF        | ro   | User data 1                                                                                                                                                                                                                        |
| Bit 17:10 | USER_D0  | 0xFF        | ro   | User data 0                                                                                                                                                                                                                        |
|           |          |             |      | System setting byte<br>It includes the system setting bytes in the loaded user system data area.<br>Bit 9: nRAM_PRT_CHK<br>Bit 8: nSTDBY_WDT                                                                                       |
| Bit 9:2   | SSB      | 0xFF        | ro   | Bit 7: nDEPSLP_WDT<br>Bit 6: nBOOT1<br>Bit 5: Unused<br>Bit 4: nSTDBY_RST<br>Bit 3: nDEPSLP_RST<br>Bit 2: nWDT_ATO_EN                                                                                                              |
| Bit 1     | FAP      | 0           | ro   | Flash access protection                                                                                                                                                                                                            |
| Bit 0     | USDERR   | 0           | ro   | User system data error<br>When this bit is set, it indicates that certain byte does not match its inverse code in the user system data area. At this point, this byte and its inverse code will be forced to 0xFF when being read. |

### 5.8.8 Erase/program protection status register (FLASH\_EPPS)

| Bit      | Name | Reset value | Type | Description                                                                                                                        |
|----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | EPPS | 0xFFFF FFFF | ro   | Erase/program protection status<br>This register reflects the erase/program protection byte status in the loaded user system data. |

### 5.8.9 Flash security library status register 0 (SLIB\_STS0)

For Flash security library only.

| Bit       | Name            | Reset value | Type | Description                                                                                                                                                                     |
|-----------|-----------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | Reserved        | 0x00        | resd | Kept at its default value.                                                                                                                                                      |
|           |                 |             |      | Extension memory sLib instruction start sector<br>00000000: Sector 0<br>00000001: Sector 1<br>00000010: Sector 2<br>...                                                         |
| Bit 23:16 | EM_SLIB_INST_SS | 0xFF        | ro   | 00001001: Sector 9 (the last sector of 256 KB main Flash memory)<br>...                                                                                                         |
|           |                 |             |      | 00010011: Sector 19 (the last sector of 128 KB main Flash memory)<br>11111111: None<br>Others: Invalid                                                                          |
| Bit 15:4  | Reserved        | 0x000       | resd | Kept at its default value.                                                                                                                                                      |
| Bit 3     | SLIB_ENF        | 0           | ro   | sLib enabled flag<br>When this bit is set, it indicates that the main Flash memory is partially or completely (depending on the setting of SLIB_STS1) used as security library. |
| Bit 2     | EM_SLIB_ENF     | 0           | ro   | Extension memory sLib enabled flag                                                                                                                                              |

|       |            |   |      |                                                                                                                                                                                                                                      |
|-------|------------|---|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |   |      | When this bit is set, it indicates that the boot memory is used as the Flash extension area (BTM_AP_ENF is set) and stores security library code.                                                                                    |
| Bit 1 | Reserved   | 0 | resd | Kept at its default value.                                                                                                                                                                                                           |
| Bit 0 | BTM_AP_ENF | 0 | ro   | Boot memory store application code enabled flag<br>When this bit is set, it indicates that the boot memory can be used as main Flash extension area to store user application code; otherwise, it is only used for system boot code. |

### 5.8.10 Flash security library status register 1 (SLIB\_STS1)

For Flash security library only.

| Bit       | Name         | Reset value | Type | Description                                                                                                                                                                                                   |
|-----------|--------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:22 | SLIB_ES      | 0x3FF       | ro   | sLib end sector<br>0000000000: Sector 0<br>0000000001: Sector 1<br>0000000010: Sector 2<br>...<br>0000111111: Sector 63<br>...<br>0001111111: Sector 127 (the last sector of 256KB/128KB main Flash memory)   |
| Bit 21:11 | SLIB_INST_SS | 0x7FF       | ro   | sLib instruction start sector<br>0000000000: Sector 0<br>0000000001: Sector 1<br>0000000010: Sector 2<br>...<br>0000111111: Sector 127 (the last sector of 256KB/128KB main Flash memory)<br>1111111111: None |
| Bit 10:0  | SLIB_SS      | 0x7FF       | ro   | sLib start sector<br>0000000000: Sector 0<br>0000000001: Sector 1<br>0000000010: Sector 2<br>...<br>0000111111: Sector 63<br>...<br>0001111111: Sector 127 (the last sector of 256KB/128KB main Flash memory) |

### 5.8.11 Security library password clear register (SLIB\_PWD\_CLR)

For Flash security library only.

| Bit      | Name          | Reset value | Type | Description                                                                                                                                                                                                                     |
|----------|---------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | SLIB_PCLR_VAL | 0x0000 0000 | wo   | sLib password clear value<br>This register is used to key in a correct sLib password in order to unlock sLib functions.<br>The write status of this register is indicated by bit [0] and bit [1] of the SLIB_MISC_STS register. |

## 5.8.12 Security library additional status register (SLIB\_MISC\_STS)

For Flash security library only.

| Bit      | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                            |
|----------|--------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:3 | Reserved     | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                                                                                             |
| Bit 2    | SLIB_ULKF    | 0           | ro   | sLib unlock flag<br>When this bit is set, it indicates that sLib-related setting registers can be configured.                                                                                                                                                                                          |
| Bit 1    | SLIB_PWD_OK  | 0           | ro   | sLib password ok<br>This bit is set by hardware when the password is correct.                                                                                                                                                                                                                          |
| Bit 0    | SLIB_PWD_ERR | 0           | ro   | sLib password error<br>This bit is set by hardware when the password is incorrect and the setting value of the password clear register is different from 0xFFFF FFFF.<br>Note: When this bit is set, the hardware will no longer agree to re-program the password clear register until the next reset. |

## 5.8.13 Flash CRC address register (FLASH\_CRC\_ADDR)

For the main Flash memory and its extension area.

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                       |
|----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | CRC_ADDR | 0x0000 0000 | wo   | CRC address<br>The register is used to select the start address of a sector to be CRC checked.<br>Note: The CRC address must align with the sector start address. |

*Note: All these bits are write-only, and return no response when being read.*

## 5.8.14 Flash CRC check control register (FLASH\_CRC\_CTRL)

For the main Flash memory and its extension area.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                   |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:17 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                    |
| Bit 16    | CRC_STRT | 0           | wo   | CRC start<br>This bit is used to enable CRC check for user code or sLib code. It is automatically cleared after enabling CRC by hardware.<br>Note:<br>CRC data ranges from CRC_ADDR+CRC_SN*1. |
| Bit 15:0  | CRC_SN   | 0x0000      | wo   | CRC sector number<br>This bit is used to set the number of sectors for CRC check.                                                                                                             |

## 5.8.15 Flash CRC check result register (FLASH\_CRC\_CHK)

For the main Flash memory and its extension area.

| Bit      | Name    | Reset value | Type | Description      |
|----------|---------|-------------|------|------------------|
| Bit 31:0 | CRC_CHK | 0x0000 0000 | ro   | CRC check result |

*Note: All these bits are read-only, and return no response when being written.*

## 5.8.16 Security library password setting register (SLIB\_SET\_PWD)

For Flash security library password setting only.

| Bit      | Name          | Reset value | Type | Description                                                                                                                                                                            |
|----------|---------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | SLIB_PSET_VAL | 0x0000 0000 | wo   | sLib password setting value<br>Note: This register can be written only after sLib is unlocked. It is used to set a password of sLib. Writing 0xFFFF_FFFF or 0x0000_0000 has no effect. |

*Note: All these bits are write-only, and return 0 when being read.*

## 5.8.17 Security library address setting register (SLIB\_SET\_RANGE)

For Flash security library address setting only.

| Bit       | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                        |
|-----------|--------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:22 | SLIB_ES_SET  | 0x000       | wo   | sLib end sector setting<br>These bits are used to set the security library end sector.<br>0000000000: Sector 0<br>0000000001: Sector 1<br>0000000010: Sector 2<br>...<br>0000111111: Sector 63<br>...<br>0001111111: Sector 127 (the last sector of 256KB/128KB main Flash memory)                                                 |
| Bit 21:11 | SLIB_ISS_SET | 0x000       | wo   | sLib instruction start sector setting<br>These bits are used to set the security library instruction start sector.<br>0000000000: Sector 0<br>0000000001: Sector 1<br>0000000010: Sector 2<br>...<br>0000011111: Sector 63<br>...<br>0000111111: Sector 127 (the last sector of 256KB/128KB main Flash memory)<br>1111111111: None |
| Bit 10:0  | SLIB_SS_SET  | 0x000       | wo   | sLib start sector setting<br>These bits are used to set the security library start sector.<br>0000000000: Sector 0<br>0000000001: Sector 1<br>0000000010: Sector 2<br>...<br>0000011111: Sector 63<br>...<br>0000111111: Sector 127 (the last sector of 256KB/128KB main Flash memory)                                             |

*Note:*

*All these bits are write-only, and return 0 when being read.*

*This register can be written only when security library is unlocked.*

*Being out of the Flash address range is an invalid setting.*

### 5.8.18 Flash extension memory security library setting register (EM\_SLIB\_SET)

For Flash extension area only.

| Bit       | Name            | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-----------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | Reserved        | 0x00        | resd | Kept at its default value.<br>Extension memory sLib instruction start sector setting<br>These bits are used to set the security library instruction area start sector.<br>00000000: Sector 0<br>00000001: Sector 1<br>00000010: Sector 2<br>...<br>00001001: Sector 9 (the last sector of 256 KB main Flash memory)<br>...<br>00010011: Sector 19 (the last sector of 128 KB main Flash memory)<br>11111111: None<br>Others: Invalid<br>Note:<br>When it is set to 0xFF, it indicates that the extension area from sector 0 to sector 3 is the security library, read-only. |
| Bit 23:16 | EM_SLIB_ISS_SET | 0x000       | wo   | Extension memory sLib setting<br>Writing 0x5AA5 can configure the Flash extension area to store the sLib code.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 15:0  | EM_SLIB_SET     | 0x000       | wo   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Note: All these bits are write-only, and return no response when being read.

### 5.8.19 Boot memory mode setting register (BTM\_MODE\_SET)

For boot memory only.

| Bit      | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                      |
|----------|--------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:8 | Reserved     | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                       |
| Bit 7:0  | BTM_MODE_SET | 0x00        | wo   | Boot memory mode setting<br>0xFF: Boot memory serves as a system area that stores system boot code<br>Others: Boot memory serves a Flash extension area that stores application code<br>Note: This register is set when the Flash access protection is disabled. |

Note: All these bits are write-only, and return no response when being read.

### 5.8.20 Security library unlock register (SLIB\_UNLOCK)

For security library register unlock only.

| Bit      | Name       | Reset value | Type | Description                                                                                                     |
|----------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | SLIB_UKVAL | 0x0000 0000 | wo   | sLib unlock key value<br>The fixed key value is 0xA35F_6D24, used for security library setting register unlock. |

Note: All these bits are write-only, and return 0 when being read.

# 6 GPIOs and IOMUX

## 6.1 Introduction

AT32F402/405 series supports up to 56 bidirectional I/O pins, namely PA0-PA15, PB0-PB15, PC0-PC15, PD2, PF0-PF1, PF4-PF7, PF11. Each of these pins features communication, control and data collection. In addition, their main features also include:

- Each pin can be configured by software as general-purpose input/output, multiplexed function and analog mode. In general-purpose output or multiplexed function mode, it can be configured as push-pull/open-drain output.
- Each pin with individual weak pull-up/pull-down capability.
- Each pin's output drive capability is configurable by software.
- Each pin can be configured as external interrupt input.
- Each pin supports write protection function.

## 6.2 Function overview

### 6.2.1 GPIO structure

I/O port registers can be accessed by words, half-words or bytes, and each I/O port bit can be programmed freely.

Figure 6-1 GPIO basic structure



## 6.2.2 GPIO reset status

After power-on or system reset, all pins other than SWD pins are configured as floating input mode.

For SWD pins: PA13/SWDIO is configured as alternate function pull-up mode, PA14/SWCLK as alternate function pull-down mode, and PB3/SWO as alternate function without pull-up/pull-down mode.

## 6.2.3 General-purpose input configuration

| Mode            | IOMC | PULL |
|-----------------|------|------|
| Floating input  |      | 00   |
| Pull-down input | 00   | 10   |
| Pull-up input   |      | 01   |

When an I/O port is configured as general-purpose input:

- Get I/O states by reading the input data register.
- Schmitt-trigger input is activated.

*Note: In floating input mode, it is recommended to set the unused pins as analog mode in order to avoid leakage caused by interferences from unused pins in a complex environment.*

## 6.2.4 Analog mode configuration

| Mode        | IOMC | PULL   |
|-------------|------|--------|
| Analog mode | 11   | Unused |

When an I/O port is configured as analog mode:

- Schmitt-trigger input is disabled.
- Output data register is invalid.
- Pull-up/pull-down configuration is invalid.
- I/O states cannot be obtained by reading the input data register.

## 6.2.5 General-purpose output configuration

| Mode                                 | IOMC | OM | HDRV                                                | ODRV[1:0] | PULL     |
|--------------------------------------|------|----|-----------------------------------------------------|-----------|----------|
| Push-pull without pull-up/pull-down  | 01   | 0  |                                                     |           | 00 or 11 |
| Push-pull with pull-up               | 01   | 0  | 000: Output mode, normal sourcing/sinking strength  |           | 01       |
| Push-pull with pull-down             | 01   | 0  | 001: Output mode, large sourcing/sinking strength   |           | 10       |
| Open-drain without pull-up/pull-down | 01   | 1  | 010: Output mode, normal sourcing/sinking strength  |           | 00 or 11 |
| Open-drain with pull-up              | 01   | 1  | 011: Output mode, normal sourcing/sinking strength  |           | 01       |
| Open-drain with pull-down            | 01   | 1  | 1xx: Output mode, maximum sourcing/sinking strength |           | 10       |

When an I/O port is configured as general-purpose output:

- Schmitt-trigger input is activated.
- In open-drain mode, output 0 when the output data register is configured as 0. When the output data register is configured as 1, the pin is in high-impedance state if there is no internal pull-up/pull-down, or the pin is pulled up to 1 or pulled down to 0 if there is internal pull-up or pull-down.
- In push-pull output mode, output data register is used to output 0/1.

- Get I/O states by reading the input data register.
- GPIO set/clear register is used to set/clear the corresponding GPIO output data registers.

*Note: If both IOCB and IOSB bits are set in the GPIO set/clear register, the IOSB takes priority.*

## 6.2.6 I/O port write protection

Each I/O port supports write protection function. When write protection is enabled, I/O port configuration cannot be modified until the next reset or power-on.

## 6.2.7 IOMUX structure

Several peripheral functions can be mapped on each IO pin. Peripheral input/output corresponding to an I/O pin is selected through IOMUX input/output table. Each I/O pin has up to 16 IOMUX mapping options for flexible selection, configured through the GPIOx\_MUXL (for pin0 to pin7) and GPIOx\_MUXH (for pin8 to pin15) registers.

Each I/O pin is connected to only one peripheral's pin by setting the GPIOx\_MUXL or GPIOx\_MUXH register so that there can be no conflict between peripherals sharing the same pin.

While being used as multiplexed function input, the I/O pin is disconnected from GPIO controller and it is controlled by IOMUX controller.

In multiplexed input mode, the I/O pin can be configured as multiplexed mode by setting the GPIOx\_CFGR register, and it can be configured as floating, pull-up/pull-down by setting the GPIOx\_PULL register according to the peripheral characteristics.

When used as multiplexed output or bidirectional IOMUX, the I/O pin can be configured as multiplexed mode by setting the GPIOx\_CFGR register, as push-pull/open-drain mode by setting the GPIOx\_OMODE register or pull-up/pull-down by setting the GPIOx\_PULL register according to the peripheral characteristics. Configure output drive capability by setting the GPIOx\_ODRVR and GPIOx\_HDRV register.

Figure 6-2 IOMXU Structure



## 6.2.8 Multiplexed function configuration

| Mode                                                      | IOMC | OM | HDRV                                                                                                                                    | ODRV[1:0] | PULL     |
|-----------------------------------------------------------|------|----|-----------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|
| Multiplexed function push-pull without pull-up/pull-down  | 10   | 0  |                                                                                                                                         |           | 00 or 11 |
| Multiplexed function push-pull with pull-up               | 10   | 0  |                                                                                                                                         |           | 01       |
| Multiplexed function push-pull with pull-down             | 10   | 0  | 000: output mode, normal sourcing/sinking strength                                                                                      |           | 10       |
| Multiplexed function open-drain without pull-up/pull-down | 10   | 1  | 001: output mode, large sourcing/sinking strength                                                                                       |           | 00 or 11 |
| Multiplexed function open-drain with pull-up              | 10   | 1  | 010: output mode, normal sourcing/sinking strength                                                                                      |           | 01       |
| Multiplexed function open-drain with pull-down            | 10   | 1  | 011: output mode, normal sourcing/sinking strength                                                                                      |           | 10       |
| Multiplexed function input without pull-up/pull-down      | 10   | x  | 1xx: output mode, maximum sourcing/sinking strength<br>Valid for multiplexed function output or bidirectional multiplexed function only |           | 00 or 11 |
| Multiplexed function input with pull-up                   | 10   | x  |                                                                                                                                         |           | 01       |
| Multiplexed function input with pull-down                 | 10   | x  |                                                                                                                                         |           | 10       |

When an I/O port is configured as multiplexed function:

- Schmitt-trigger input is activated.
- In open-drain output mode, output 0 when the peripheral outputs 0. When the peripheral outputs 1, the pin is in high-impedance state if there is no internal pull-up/pull-down, or it is pulled up to 1 or pulled down to 0 if there is internal pull-up or pull-down.
- In push-pull output mode, output 0/1 according to the peripheral output.
- Get an I/O pin state by reading input data register.

## 6.2.9 IOMUX input/output

The multiplexed function of each I/O port line is configured through the GPIOx\_MUXL (from pin0 to pin7) or GPIOx\_MUXH (from pin8 to pin15) register.

Table 6-1 Port A multiplexed function configuration with GPIOA\_MUX\* register

| Pin name    | MUX0        | MUX1                 | MUX2     | MUX3      | MUX4      | MUX5               | MUX6               | MUX7          |
|-------------|-------------|----------------------|----------|-----------|-----------|--------------------|--------------------|---------------|
| <b>PA0</b>  |             | TMR2_CH1<br>TMR2_EXT |          | TMR9_CH2C | I2C2_SCL  |                    | USART2_RX          | USART2_CS     |
| <b>PA1</b>  |             | TMR2_CH2             |          | TMR9_CH1C | I2C2_SDA  | I2C1_SMBA          | I2SF5_SD           | USART2_RTS_DE |
| <b>PA2</b>  |             | TMR2_CH3             |          | TMR9_CH1  |           | I2SF5_CKIN         |                    | USART2_TX     |
| <b>PA3</b>  |             | TMR2_CH4             |          | TMR9_CH2  |           | I2S2_MCK           |                    | USART2_RX     |
| <b>PA4</b>  |             |                      |          |           | I2C1_SCL  | SPI1_CS/I2S1_WS    | SPI3_CS/I2S3_WS    | USART2_CK     |
| <b>PA5</b>  |             | TMR2_CH1<br>TMR2_EXT |          |           |           | SPI1_SCK/I2S1_CK   | USART3_CK          | USART3_RX     |
| <b>PA6</b>  |             | TMR1_BRK             | TMR3_CH1 |           |           | SPI1_MISO/I2S1_MCK | I2S2_MCK           | USART3_CS     |
| <b>PA7</b>  |             | TMR1_CH1C            | TMR3_CH2 |           | I2C3_SCL  | SPI1_MOSI/I2S1_SD  |                    | USART3_TX     |
| <b>PA8</b>  | CLKOUT      | TMR1_CH1             |          | TMR9_BRK  | I2C3_SCL  |                    |                    | USART1_CK     |
| <b>PA9</b>  | CLKOUT      | TMR1_CH2             |          |           | I2C3_SMBA | SPI2_SCK/I2S2_CK   |                    | USART1_TX     |
| <b>PA10</b> | ERTC_REFI_N | TMR1_CH3             |          |           |           | SPI2_MOSI/I2S2_SD  | I2SF5_SD           | USART1_RX     |
| <b>PA11</b> |             | TMR1_CH4             |          |           | I2C2_SCL  | SPI2_CS/I2S2_WS    | I2C1_SMBA          | USART1_CS     |
| <b>PA12</b> |             | TMR1_EXT             |          |           | I2C2_SDA  | SPI2_MISO/I2S2_MCK | I2SF5_SDEXT        | USART1_RTS_DE |
| <b>PA13</b> | SWDIO       | IR_OUT               |          |           | I2C1_SDA  | I2S_SDEXT          | SPI3_MISO/I2S3_MCK |               |
| <b>PA14</b> | SWCLK       |                      |          |           | I2C1_SMBA |                    | SPI3_MOSI/I2S3_SD  |               |
| <b>PA15</b> |             | TMR2_CH1<br>TMR2_EXT |          |           |           | SPI1_CS/I2S1_WS    | SPI3_CS/I2S3_WS    | USART1_TX     |

| Pin name    | MUX8      | MUX9        | MUX10          | MUX11     | MUX12 | MUX13     | MUX14     | MUX15    |
|-------------|-----------|-------------|----------------|-----------|-------|-----------|-----------|----------|
| <b>PA0</b>  | USART4_TX |             |                |           |       |           |           | EVENTOUT |
| <b>PA1</b>  | USART4_RX |             |                | QSPI1_IO3 |       |           |           | EVENTOUT |
| <b>PA2</b>  |           |             |                | QSPI1_CS  |       |           |           | EVENTOUT |
| <b>PA3</b>  |           |             |                |           |       |           |           | EVENTOUT |
| <b>PA4</b>  | USART6_TX | TMR14_CH1   | OTGHS1_SOF     |           |       |           |           | EVENTOUT |
| <b>PA5</b>  | USART6_RX | TMR13_CH1_C |                |           |       |           |           | EVENTOUT |
| <b>PA6</b>  | USART3_RX | TMR13_CH1   |                | QSPI1_IO0 |       | QSPI1_IO2 |           | EVENTOUT |
| <b>PA7</b>  |           | TMR14_CH1   |                | QSPI1_IO1 |       |           |           | EVENTOUT |
| <b>PA8</b>  | USART2_TX | UART7_TX    | OTGFS1_SOF     |           |       |           |           | EVENTOUT |
| <b>PA9</b>  | I2C1_SCL  | TMR14_BR_K  | OTGFS1_VBUS    |           |       |           |           | EVENTOUT |
| <b>PA10</b> | I2C1_SDA  |             | OTGFS1_ID      |           |       |           | I2SF5_MCK | EVENTOUT |
| <b>PA11</b> | USART6_TX | CAN1_RX     |                |           |       |           |           | EVENTOUT |
| <b>PA12</b> | USART6_RX | CAN1_TX     |                |           |       |           |           | EVENTOUT |
| <b>PA13</b> |           |             | OTGFS1_OE      |           |       |           |           | EVENTOUT |
| <b>PA14</b> | USART2_TX |             |                |           |       |           |           | EVENTOUT |
| <b>PA15</b> | USART2_RX | UART7_TX    | USART4_RTS_D_E | QSPI1_IO2 |       |           |           | EVENTOUT |

Table 6-2 Port B multiplexed function configuration with GPIOB\_MUX\* register

| Pin name    | MUX0      | MUX1                 | MUX2     | MUX3       | MUX4      | MUX5                 | MUX6               | MUX7          |
|-------------|-----------|----------------------|----------|------------|-----------|----------------------|--------------------|---------------|
| <b>PB0</b>  |           | TMR1_CH2C            | TMR3_CH3 |            |           | SPI1_MISO / I2S1_MCK | SPI3_MOSI/I2S3_SD  | USART2_RX     |
| <b>PB1</b>  |           | TMR1_CH3C            | TMR3_CH4 |            |           | SPI1_MOSI / I2S1_SD  | SPI2_SCK/I2S2_CK   | USART2_CK     |
| <b>PB2</b>  |           | TMR2_CH4             | TMR3_EXT |            | I2C3_SMBA |                      | SPI3_MOSI/I2S3_SD  |               |
| <b>PB3</b>  | SWO       | TMR2_CH2             |          |            | I2C2_SDA  | SPI1_SCK/I2S1_CK     | SPI3_SCK/I2S3_CK   | USART1_RX     |
| <b>PB4</b>  |           |                      | TMR3_CH1 | TMR11_BRK  | I2C3_SDA  | SPI1_MISO/I2S1_MCK   | SPI3_MISO/I2S3_MCK | USART1_CTS    |
| <b>PB5</b>  |           |                      | TMR3_CH2 | TMR10_BRK  | I2C3_SMBA | SPI1_MOSI/I2S1_SD    | SPI3_MOSI/I2S3_SD  | USART1_CK     |
| <b>PB6</b>  |           |                      | TMR4_CH1 | TMR10_CH1C | I2C1_SCL  | I2S1_MCK             | I2SF5_WS           | USART1_TX     |
| <b>PB7</b>  |           |                      | TMR4_CH2 | TMR11_CH1C | I2C1_SDA  |                      | I2SF5_CK           | USART1_RX     |
| <b>PB8</b>  |           | TMR2_CH1<br>TMR2_EXT | TMR4_CH3 | TMR10_CH1  | I2C1_SCL  |                      | I2SF5_SDEXT        | USART1_TX     |
| <b>PB9</b>  | IR_OUT    | TMR2_CH2             | TMR4_CH4 | TMR11_CH1  | I2C1_SDA  | SPI2_CS/I2S2_WS      | I2SF5_SD           | I2C2_SDA      |
| <b>PB10</b> |           | TMR2_CH3             |          |            | I2C2_SCL  | SPI2_SCK/I2S2_CK     | I2S3_MCK           | USART3_TX     |
| <b>PB11</b> |           | TMR2_CH4             |          |            | I2C2_SDA  | I2SF5_CKIN           |                    | USART3_RX     |
| <b>PB12</b> |           | TMR1_BRK             |          |            | I2C2_SMBA | SPI2_CS/I2S2_WS      | SPI3_SCK/I2S3_CK   |               |
| <b>PB13</b> | CLKOUT    | TMR1_CH1C            |          |            | I2C3_SMBA | SPI2_SCK/I2S2_CK     | I2SF5_CK           | I2C3_SCL      |
| <b>PB14</b> |           | TMR1_CH2C            |          |            | I2C3_SDA  | SPI2_MISO/I2S2_MCK   | I2S_SDEXT          | USART3_RTS_DE |
| <b>PB15</b> | RTC_REFIN | TMR1_CH3C            |          |            | I2C3_SCL  | SPI2_MOSI/I2S2_SD    |                    |               |

| Pin name    | MUX8           | MUX9       | MUX10            | MUX11     | MUX12 | MUX13    | MUX14     | MUX15    |
|-------------|----------------|------------|------------------|-----------|-------|----------|-----------|----------|
| <b>PB0</b>  | USART3_CK      |            |                  | QSPI1_IO0 |       |          | I2SF5_CK  | EVENTOUT |
| <b>PB1</b>  | USART3_RT_S_DE | TMR14_CH1  |                  | QSPI1_SCK |       |          | I2SF5_WS  | EVENTOUT |
| <b>PB2</b>  |                | TMR14_CH1C |                  | QSPI1_SCK |       |          |           | EVENTOUT |
| <b>PB3</b>  | USART1_RT_S_DE | UART7_RX   | USART5_TX        | QSPI1_IO3 |       |          |           | EVENTOUT |
| <b>PB4</b>  |                | UART7_TX   | USART5_RX        | QSPI1_SCK |       |          | I2S_SDEXT | EVENTOUT |
| <b>PB5</b>  | USART5_RX      |            | USART5_CK_RTS_DE | QSPI1_IO0 |       |          |           | EVENTOUT |
| <b>PB6</b>  | USART5_TX      |            | USART4_CK        | QSPI1_CS  |       |          |           | EVENTOUT |
| <b>PB7</b>  | USART4_CTS     |            |                  | QSPI1_IO1 |       |          |           | EVENTOUT |
| <b>PB8</b>  | USART5_RX      | CAN1_RX    |                  |           |       |          | I2SF5_SD  | EVENTOUT |
| <b>PB9</b>  | USART5_TX      | CAN1_TX    | I2S1_MCK         | QSPI1_CS  |       |          |           | EVENTOUT |
| <b>PB10</b> |                |            |                  | QSPI1_IO1 |       | QSPI1_CS |           | EVENTOUT |
| <b>PB11</b> |                | TMR13_BRK  |                  | QSPI1_IO0 |       |          |           | EVENTOUT |
| <b>PB12</b> | USART3_CK      |            | OTGHS1_ID        |           |       |          | I2SF5_WS  | EVENTOUT |
| <b>PB13</b> | USART3_CTS     |            | OTGHS1_VBUS      |           |       |          |           | EVENTOUT |
| <b>PB14</b> |                |            |                  |           |       |          |           | EVENTOUT |
| <b>PB15</b> |                |            |                  |           |       |          |           | EVENTOUT |

Table 6-3 Port C multiplexed function configuration with GPIOC\_MUX\* register

| Pin name | MUX0   | MUX1     | MUX2     | MUX3      | MUX4      | MUX5               | MUX6               | MUX7      |
|----------|--------|----------|----------|-----------|-----------|--------------------|--------------------|-----------|
| PC0      |        |          |          |           | I2C3_SCL  |                    |                    | I2C1_SCL  |
| PC1      |        |          |          |           | I2C3_SDA  | SPI3_MOSI/I2S3_SD  | SPI2_MOSI/I2S2_SD  | I2C1_SDA  |
| PC2      |        |          |          |           |           | SPI2_MISO/I2S2_MCK | I2S_SDEXT          |           |
| PC3      |        |          |          |           |           | SPI2_MOSI/I2S2_SD  |                    |           |
| PC4      |        |          |          | TMR9_CH1  |           | I2S1_MCK           |                    | USART3_TX |
| PC5      |        |          |          | TMR9_CH2  | I2C1_SMBA |                    |                    | USART3_RX |
| PC6      |        | TMR1_CH1 | TMR3_CH1 |           | I2C1_SCL  | I2S2_MCK           |                    |           |
| PC7      |        | TMR1_CH2 | TMR3_CH2 |           | I2C1_SDA  | SPI2_SCK/I2S2_CK   | I2S3_MCK           |           |
| PC8      |        | TMR1_CH3 | TMR3_CH3 |           |           |                    | I2SF5_MCK          | UART8_TX  |
| PC9      | CLKOUT | TMR1_CH4 | TMR3_CH4 |           | I2C3_SDA  | I2SF5_CKIN         |                    | UART8_RX  |
| PC10     |        |          |          |           |           |                    | SPI3_SCK/I2S3_CK   | USART3_TX |
| PC11     |        |          |          |           |           | I2S_SDEXT          | SPI3_MISO/I2S3_MCK | USART3_RX |
| PC12     |        |          |          | TMR11_CH1 | I2C2_SDA  |                    | SPI3_MOSI/I2S3_SD  | USART3_CK |
| PC13     |        |          |          |           |           |                    |                    |           |
| PC14     |        |          |          |           |           |                    |                    |           |
| PC15     |        |          |          |           |           |                    |                    |           |

| Pin name | MUX8              | MUX9       | MUX10     | MUX11     | MUX12 | MUX13 | MUX14 | MUX15    |
|----------|-------------------|------------|-----------|-----------|-------|-------|-------|----------|
| PC0      | USART6_T_X        | UART7_TX   |           |           |       |       |       | EVENTOUT |
| PC1      | USART6_R_X        | UART7_RX   |           |           |       |       |       | EVENTOUT |
| PC2      | UART8_TX          |            |           |           |       |       |       | EVENTOUT |
| PC3      | UART8_RX          |            |           |           |       |       |       | EVENTOUT |
| PC4      |                   | TMR13_CH1  |           | QSPI1_IO2 |       |       |       | EVENTOUT |
| PC5      |                   | TMR13_CH1C |           | QSPI1_IO3 |       |       |       | EVENTOUT |
| PC6      | USART6_T_X        | UART7_TX   |           |           |       |       |       | EVENTOUT |
| PC7      | USART6_R_X        | UART7_RX   |           |           |       |       |       | EVENTOUT |
| PC8      | USART6_C_K_RTS_DE |            |           | QSPI1_IO2 |       |       |       | EVENTOUT |
| PC9      | I2C1_SDA          |            | OTGHS1_OE | QSPI1_IO0 |       |       |       | EVENTOUT |
| PC10     | USART4_T_X        |            |           | QSPI1_IO1 |       |       |       | EVENTOUT |
| PC11     | USART4_R_X        |            |           | QSPI1_CS  |       |       |       | EVENTOUT |
| PC12     | USART4_C_K        |            | USART5_TX |           |       |       |       | EVENTOUT |
| PC13     |                   |            |           |           |       |       |       | EVENTOUT |
| PC14     |                   |            |           |           |       |       |       | EVENTOUT |
| PC15     |                   |            |           |           |       |       |       | EVENTOUT |

Table 6-4 Port D multiplexed function configuration with GPIOD\_MUX\* register

| Pin name | MUX0      | MUX1 | MUX2     | MUX3  | MUX4  | MUX5  | MUX6  | MUX7           |
|----------|-----------|------|----------|-------|-------|-------|-------|----------------|
| PD2      |           |      | TMR3_EXT |       |       |       |       | USART3_RT_S_DE |
| Pin name | MUX8      | MUX9 | MUX10    | MUX11 | MUX12 | MUX13 | MUX14 | MUX15          |
| PD2      | USART5_RX |      |          |       |       |       |       | EVENTOUT       |

Table 6-5 Port F multiplexed function configuration with GPIOF\_MUX\* register

| Pin name | MUX0 | MUX1      | MUX2 | MUX3 | MUX4     | MUX5              | MUX6 | MUX7 |
|----------|------|-----------|------|------|----------|-------------------|------|------|
| PF0      |      | TMR1_CH1  |      |      | I2C1_SDA |                   |      |      |
| PF1      |      | TMR1_CH2C |      |      | I2C1_SCL | SPI2_CS / I2S2_WS |      |      |
| PF4      |      | TMR2_CH1  |      |      | I2C1_SDA |                   |      |      |
| PF5      |      | TMR2_CH2  |      |      | I2C1_SCL |                   |      |      |
| PF6      |      |           |      |      | I2C2_SCL |                   |      |      |
| PF7      |      |           |      |      | I2C2_SDA |                   |      |      |
| PF11     |      |           |      |      |          |                   |      |      |

| Pin name | MUX8 | MUX9     | MUX10 | MUX11     | MUX12 | MUX13 | MUX14 | MUX15    |
|----------|------|----------|-------|-----------|-------|-------|-------|----------|
| PF0      |      |          |       |           |       |       |       | EVENTOUT |
| PF1      |      |          |       |           |       |       |       | EVENTOUT |
| PF4      |      |          |       |           |       |       |       | EVENTOUT |
| PF5      |      |          |       |           |       |       |       | EVENTOUT |
| PF6      |      | UART7_RX |       | QSPI1_IO0 |       |       |       | EVENTOUT |
| PF7      |      | UART7_TX |       |           |       |       |       | EVENTOUT |
| PF11     |      |          |       |           |       |       |       | EVENTOUT |

## 6.2.10 Peripheral MUX function configuration

IOMUX function configuration is as follows:

- To use a peripheral pin in MUX output, it is configured as multiplexed push-pull/open-drain output.
- To use a peripheral pin in MUX input, it is configured as floating input/pull-up/pull-down input.
- For ADC peripherals, the pins of analog channels should be configured as analog input/output mode.
- For I<sup>2</sup>C peripherals that intend to use pins as bidirectional functions, open-drain mode is required.
- For USB peripheral pins, configure the corresponding IOMUX and enable corresponding clocks in CRM; there is no need of GPIO status configuration.

## 6.2.11 IOMUX mapping priority

The unique peripheral multiplexed function can be configured through the GPIOx\_MUXL/GPIOx\_MUXH register, except individual pins that may be directly owned by hardware.

Some pins have been directly owned by specific hardware feature, whatever GPIO configuration.

Table 6-6 Pins owned by hardware

| Pin  | Enable bit                                                                                                                      | Description                                  |
|------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| PA0  | PWC_CTRLTS[8] = 1                                                                                                               | Once enabled, PA0 pin acts as WKUP1 of PWC.  |
| PC13 | PWC_CTRLSTS[9] = 1                                                                                                              | Once enabled, PC13 pin acts as WKUP2 of PWC. |
| PB5  | PWC_CTRLTS[13] = 1                                                                                                              | Once enabled, PB5 pin acts as WKUP6 of PWC.  |
|      | (ERTC_CTRL[23]=1) <br>(ERTC_CTRL[22:21]!=00) <br>(ERTC_CTRL[11]=1&<br>ERTC_TAMP[17]=0) <br>(ERTC_TAMP[0]=1&<br>ERTC_TAMP[16]=0) |                                              |
| PC13 | (ERTC_CTRL[11]=1&<br>ERTC_TAMP[17]=1) <br>(ERTC_TAMP[0]=1&<br>ERTC_TAMP[16]=1) <br>(ERTC_TAMP[3]=1)                             | Once enabled, PC13 pin acts as RTC channel.  |
| PA0  | (ERTC_TAMP[0]=1&<br>ERTC_TAMP[16]=1) <br>(ERTC_TAMP[3]=1)                                                                       | Once enabled, PA0 pin acts as TAMPER2_BPR.   |
| PC14 | CMR_BPDC[0]=1                                                                                                                   | Once enabled, PC14 acts as LEXT channel.     |
| PC15 | CMR_BPDC[0]=1 &<br>CMR_BPDC[2]=0                                                                                                | Once enabled, PC15 acts as LEXT channel.     |
| PF0  | CMR_CTRL[16]=1                                                                                                                  | Once enabled, PF0 acts as HEXT channel.      |
| PF1  | CMR_CTRL[16]=1&<br>CMR_CTRL[18]=0                                                                                               | Once enabled, PF1 acts as HEXT channel.      |

Note: PA0 or PC13 cannot be used as TAMPER\_BPR function or WKUP of PWC simultaneously.

## 6.2.12 External interrupt/wake-up lines

Each pin can be used as an external interrupt input. The corresponding pin should be configured as input mode.

## 6.3 GPIO registers

The table below lists GPIO register map and their reset values. These peripheral registers can be accessed by bytes (8 bits), half-words (16 bits) or words (32 bits).

Table 6-7 GPIO register map and reset values

| Register                | Offset | Reset value                   |
|-------------------------|--------|-------------------------------|
| GPIOA_CFGR              | 0x00   | 0x2800 0000                   |
| GPIOx_CFGR(x =B,C,D,F)  | 0x00   | 0x0000 0080(B)<br>0x0000 0000 |
| GPIOx_OMODER            | 0x04   | 0x0000 0000                   |
| GPIOx_ODRVR             | 0x08   | 0x0000 00C0(B)<br>0x0000 0000 |
| GPIOA_PULL              | 0x0C   | 0x2400 0000(A)                |
| GPIOx_PULL(x = B,C,D,F) | 0x0C   | 0x0000 0000<br>0x0080 0000(F) |
| GPIOx_IDT               | 0x10   | 0x0000 XXXX                   |
| GPIOx_ODT               | 0x14   | 0x0000 0000                   |
| GPIOx_SCR               | 0x18   | 0x0000 0000                   |
| GPIOx_WPR               | 0x1C   | 0x0000 0000                   |
| GPIOx_MUXL              | 0x20   | 0x0000 0000                   |
| GPIOx_MUXH              | 0x24   | 0x0000 0000                   |
| GPIOx_CLR               | 0x28   | 0x0000 0000                   |
| GPIOx_TOGR              | 0x2C   | 0x0000 0000                   |
| GPIOx_HDRV              | 0x3C   | 0x0000 0000                   |

### 6.3.1 GPIO configuration register (GPIOx\_CFGR) (x=A..F)

Address offset: 0x00

Reset value: 0x2800\_0000 for port A, 0x0000\_0080 for port B, and 0x00000000 for other ports.

| Bit         | Name  | Reset value | Type | Description                                                                                                                                                                                            |
|-------------|-------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 2y+1:2y | IOMCy | 0x2800 0000 | rw   | GPIOx mode configuration (y=0~15)<br>This field is used to configure the GPIOx mode:<br>00: Input mode (reset state)<br>01: General-purpose output mode<br>10: Multiplexed function mode<br>11: Analog |

### 6.3.2 GPIO output mode register (GPIOx\_OMODE) (x=A..F)

| Bit       | Name     | Reset value | Type | Description |
|-----------|----------|-------------|------|-------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Always 0.   |

  

|          |    |        |    |                                                                                                                                                       |
|----------|----|--------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:0 | OM | 0x0000 | rw | GPIOx output mode configuration (y=0..15)<br>This field is used to configure the output mode of GPIOx:<br>0: Push-pull (reset state)<br>1: Open-drain |
|----------|----|--------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------|

### 6.3.3 GPIO drive capability register (GPIOx\_ODRVR) (x=A..F)

Address offset: 0x08

Reset value: 0x0000\_00C0 for port B, and 0x0000\_0000 for other ports.

| Bit         | Name  | Reset value | Type | Description                                                                                                         |
|-------------|-------|-------------|------|---------------------------------------------------------------------------------------------------------------------|
|             |       |             |      | GPIOx drive capability (y=0...15)                                                                                   |
|             |       |             |      | This field is used to configure the I/O port drive capability                                                       |
| Bit 2y+1:2y | ODRVy | 0x0000 0000 | rw   | x0: Normal sourcing/sinking strength<br>01: Large sourcing/sinking strength<br>11: Normal sourcing/sinking strength |
|             |       |             |      |                                                                                                                     |

### 6.3.4 GPIO pull-up/pull-down register (GPIOx\_PULL) (x=A..F)

Address offset: 0x0C

Reset value: 0x2400\_0000 for port A, 0x0000\_0000 for port B, and 0x0000\_0000 for other ports.

| Bit         | Name  | Reset value | Type | Description                                                            |
|-------------|-------|-------------|------|------------------------------------------------------------------------|
|             |       |             |      | GPIOx pull-up/pull-down configuration (y=0...15)                       |
|             |       |             |      | This field is used to configure the pull-up/pull-down of the I/O port. |
| Bit 2y+1:2y | PULLy | 0x2400 0000 | rw   | 00, 11: No pull-up/pull-down<br>01: Pull-up<br>10: Pull-down           |
|             |       |             |      |                                                                        |

### 6.3.5 GPIO input data register (GPIOx\_IDT) (x=A..F)

| Bit       | Name     | Reset value | Type | Description                                                                                    |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Always 0.                                                                                      |
| Bit 15:0  | IDT      | 0xFFFF      | ro   | GPIOx input data<br>It indicates the input status of I/O port. Each bit corresponds to an I/O. |

### 6.3.6 GPIO output data register (GPIOx\_ODT) (x=A..F)

| Bit       | Name     | Reset value | Type | Description                                                                                                               |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Always 0.                                                                                                                 |
| Bit 15:0  | ODT      | 0x0000      | rw   | GPIOx output data<br>Each bit represents an I/O port.<br>It indicates the output status of I/O port.<br>0: Low<br>1: High |
|           |          |             |      |                                                                                                                           |

### 6.3.7 GPIO set/clear register (GPIOx\_SCR) (x=A..F)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                     |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | IOCB | 0x0000      | wo   | GPIOx clear bit<br>The corresponding ODT register bit is cleared by writing “1” to these bits. Otherwise, the corresponding ODT register bit remains unchanged, which acts as ODT register bit operations.<br>0: No action to the corresponding ODT bits<br>1: Clear the corresponding ODT bits |
| Bit 15:0  | IOSB | 0x0000      | wo   | GPIOx set bit<br>The corresponding ODT register bit is set by writing “1” to these bits. Otherwise, the corresponding ODT register bit remains unchanged, which acts as ODT register bit operations                                                                                             |

If both IOCB and IOSB bits are set to 1, the IOSB takes the priority.

0: No action to the corresponding ODT bits

1: Set the corresponding ODT bits

### 6.3.8 GPIO write protection register (GPIOx\_WPR) (x=A..F)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:17 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                  |
| Bit 16    | WPSEQ    | 0x0         | rw   | <p>Write protect sequence</p> <p>Write protect enable sequence bit and WPEN bit must be enabled at the same time to achieve write protection for some I/O bits.</p> <p>Write protect enable bit is executed four times in the order below: write “1” -&gt; write “0” -&gt; write “1” -&gt; read. Note that the value of WPEN bit cannot be modified during this period.</p> |
| Bit 15:0  | WPEN     | 0x0000      | rw   | <p>Write protect enable</p> <p>Each bit corresponds to an I/O port.</p> <p>0: No effect</p> <p>1: Write protect</p>                                                                                                                                                                                                                                                         |

### 6.3.9 GPIO multiplexed function low register (GPIOx\_MUXL) (x=A..F)

Address offset: 0x20

Reset value: 0x00000000

| Bit         | Name  | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 4y+3:4y | MUXLy | 0x0         | rw   | <p>Multiplexed function select for GPIOx pin y (y=0...7)</p> <p>This field is used to configure multiplexed function I/Os.</p> <p>0000: MUX0<br/>0001: MUX1<br/>0010: MUX2<br/>0011: MUX3<br/>0100: MUX4<br/>0101: MUX5<br/>0110: MUX6<br/>0111: MUX7<br/>1000: MUX8<br/>1001: MUX9<br/>1010: MUX10<br/>1011: MUX11<br/>1100: MUX12<br/>1101: MUX13<br/>1110: MUX14<br/>1111: MUX15</p> |

### 6.3.10 GPIO multiplexed function high register (GPIOx\_MUXH) (x=A..F)

| Bit               | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                |
|-------------------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 4y+3:4y MUXHy |      | 0x0         | rw   | Multiplexed function select for GPIOx pin y (y=8...15)<br>This field is used to configure multiplexed function I/Os.<br>0000: MUX0<br>0001: MUX1<br>0010: MUX2<br>0011: MUX3<br>0100: MUX4<br>0101: MUX5<br>0110: MUX6<br>0111: MUX7<br>1000: MUX8<br>1001: MUX9<br>1010: MUX10<br>1011: MUX11<br>1100: MUX12<br>1101: MUX13<br>1110: MUX14<br>1111: MUX15 |

### 6.3.11 GPIO port bit clear register (GPIOx\_CLR) (x=A..F)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                     |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                      |
| Bit 15:0  | IOCB     | 0x0000      | wo   | GPIOx clear bit<br>The corresponding ODT register bit is cleared by writing “1” to these bits. Otherwise, the corresponding ODT register bit remains unchanged, which acts as ODT register bit operations.<br>0: No action to the corresponding ODT bits<br>1: Clear the corresponding ODT bits |

### 6.3.12 GPIO port bit toggle register (GPIOx\_TOGR) (x=A..F)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                  |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                   |
|           |          |             |      | GPIOx toggle bit<br>The corresponding ODT register bit value is toggled by writing “1” to this bit, and remains unchanged when writing “0”, which acts as ODT register bit operations.<br>0: No action to the corresponding ODT bits<br>1: Toggle the corresponding ODT bits |

### 6.3.13 GPIO huge current control register (GPIOx\_HDRV) (x=A..F)

| Bit       | Name     | Reset value | Type | Description                                                                                                           |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                            |
|           |          |             |      | Huge sourcing/sinking strength control<br>0: Not active<br>1: GPIO is configured as maximum sourcing/sinking strength |

# 7 System configuration controller (SYSCFG)

## 7.1 Introduction

This device contains a set of system configuration registers. The system configuration controller is mainly set to:

- Manage the external interrupts connected to GPIOs
- Control the memory mapping mode
- Manage IRTMR GPIO configurations

## 7.2 SCFG registers

The table below shows SCFG register map and their reset values.

These peripheral registers must be accessed by words (32 bits).

Table 7-1 SCFG register map and reset value

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| SCFG_CFG1    | 0x00   | 0x0000 000X |
| SCFG_CFG2    | 0x04   | 0x0000 0000 |
| SCFG_EXINTC1 | 0x08   | 0x0000 0000 |
| SCFG_EXINTC2 | 0x0C   | 0x0000 0000 |
| SCFG_EXINTC3 | 0x10   | 0x0000 0000 |
| SCFG_EXINTC4 | 0x14   | 0x0000 0000 |
| SCFG_UHDRV   | 0x2C   | 0x0000 0000 |

### 7.2.1 SCFG configuration register 1 (SCFG\_CFG1)

| Bit      | Name        | Reset value | Type | Description                                                                                                                                                                                       |
|----------|-------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:8 | Reserved    | 0x00000000  | resd | Kept at its default value.                                                                                                                                                                        |
| Bit 7:6  | IR_SRC_SEL  | 0x0         | rw   | Infrared modulation envelope signal source selection<br>This field is used to select the infrared modulation envelope signal source.<br>00: TMR10<br>01: Reserved<br>10: Reserved<br>11: Reserved |
| Bit 5    | IR_POL      | 0x0         | rw   | Infrared output polarity selection<br>0: Infrared output (IR_OUT) is not inverted<br>1: Infrared output (IR_OUT) is inverted                                                                      |
| Bit 4:2  | Reserved    | 0x0         | resd | Kept at its default value.                                                                                                                                                                        |
| Bit 1:0  | MEM_MAP_SEL | 0xX         | ro   | Boot mode status bit<br>This bit is read-only, indicating the boot mode after reset.<br>X0: Boot from main Flash memory<br>01: Boot from system memory<br>11: Boot from internal SRAM             |

### 7.2.2 SCFG configuration register 2 (SCFG\_CFG2)

| Bit       | Name           | Reset value | Type  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|----------------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:30 | I2S_FD         | 0x0         | rw    | I <sup>2</sup> S full duplex configuration bit<br>It is used to configure I <sup>2</sup> S full duplex mode.<br>This bit must remain 00 if there is no need for I <sup>2</sup> S full duplex configuration. Refer to Section 13.3.2 for details.<br>00: SPI/I <sup>2</sup> S1~3 operates separately<br>01: I <sup>2</sup> S1 and I <sup>2</sup> S3 are configured as full-duplex mode<br>10: I <sup>2</sup> S2 and I <sup>2</sup> S3 are configured as full-duplex mode<br>11: I <sup>2</sup> S1 and I <sup>2</sup> S2 are configured as full-duplex mode |
| Bit 29:9  | Reserved       | 0x0000 0000 | resd  | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 8     | SRAM_OPERR_STS | 0           | rc_w1 | SRAM odd parity error status<br>This bit is cleared by writing "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|         |               |            |      |                                                                                                                                                                                                                                                                                                                    |
|---------|---------------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |               |            |      | 0: No SRAM odd parity error<br>1: SRAM odd parity error                                                                                                                                                                                                                                                            |
| Bit 7:3 | Reserved      | 0x0000 000 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                         |
| Bit 2   | PVM_LK        | 0x0        | rw   | PVM lock enable<br>0: Disconnect the PVM interrupt with TMR1/TMR9/TMR10/11/12/13/14 brake input. The PVMSEL and PVMEN bits can be modified by software.<br>1: Connect the PVM interrupt with TMR1/TMR9/TMR10/11/12/13/14 brake input. The PVMSEL and PVMEN bits are read-only, and cannot be modified by software. |
| Bit 1   | SRAM_OPERR_LK | 0          | rw   | SRAM odd parity error lock enable<br>0: Disconnect SRAM odd parity error with TMR1/TMR9/TMR10/11/13/14 brake input.<br>1: Connect SRAM odd parity error with TMR1/TMR9/TMR10/11/13/14 brake input.                                                                                                                 |
| Bit 0   | LOCKUP_LK     | 0x0        | rw   | CM4F LOCKUP bit enable                                                                                                                                                                                                                                                                                             |

### 7.2.3 SCFG external interrupt configuration register 1 (SCFG\_EXINTC1)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                    |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                     |
| Bit 15:12 | EXINT3   | 0x0         | rw   | EXINT3 input source configuration<br>These bits are used to select the input source for the EXINT3 external interrupt.<br>0000: GPIOA pin 3<br>0001: GPIOB pin 3<br>0010: GPIOC pin 3<br>Others: Reserved                      |
| Bit 11:8  | EXINT2   | 0x0         | rw   | EXINT2 input source configuration<br>These bits are used to select the input source for the EXINT2 external interrupt.<br>0000: GPIOA pin 2<br>0001: GPIOB pin 2<br>0010: GPIOC pin 2<br>0011: GPIOD pin 2<br>Others: Reserved |
| Bit 7:4   | EXINT1   | 0x0         | rw   | EXINT1 input source configuration<br>These bits are used to select the input source for the EXINT1 external interrupt.<br>0000: GPIOA pin 1<br>0001: GPIOB pin 1<br>0010: GPIOC pin 1<br>0101: GPIOF pin 1<br>Others: Reserved |
| Bit 3:0   | EXINT0   | 0x0         | rw   | EXINT0 input source configuration<br>These bits are used to select the input source for the EXINT0 external interrupt.<br>0000: GPIOA pin 0<br>0001: GPIOB pin 0<br>0010: GPIOC pin 0<br>0101: GPIOF pin 0<br>Others: Reserved |

## 7.2.4 SCFG external interrupt configuration register 2 (SCFG\_EXINTC2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                    |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                     |
| Bit 15:12 | EXINT7   | 0x0         | rw   | EXINT7 input source configuration<br>These bits are used to select the input source for the EXINT7 external interrupt.<br>0000: GPIOA pin 7<br>0001: GPIOB pin 7<br>0010: GPIOC pin 7<br>0101: GPIOF pin 7<br>Others: Reserved |
| Bit 11:8  | EXINT6   | 0x0         | rw   | EXINT6 input source configuration<br>These bits are used to select the input source for the EXINT6 external interrupt<br>0000: GPIOA pin 6<br>0001: GPIOB pin 6<br>0010: GPIOC pin 6<br>0101: GPIOF pin 6<br>Others: Reserved  |
| Bit 7:4   | EXINT5   | 0x0         | rw   | EXINT5 input source configuration<br>These bits are used to select the input source for the EXINT5 external interrupt.<br>0000: GPIOA pin 5<br>0001: GPIOB pin 5<br>0010: GPIOC pin 5<br>0101: GPIOF pin 5<br>Others: Reserved |
| Bit 3:0   | EXINT4   | 0x0         | rw   | EXINT4 input source configuration<br>These bits are used to select the input source for the EXINT4 external interrupt.<br>0000: GPIOA pin 4<br>0001: GPIOB pin 4<br>0010: GPIOC pin 4<br>0101: GPIOF pin 4<br>Others: Reserved |

## 7.2.5 SCFG external interrupt configuration register 3 (SCFG\_EXINTC3)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                          |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                           |
| Bit 15:12 | EXINT11  | 0x0         | rw   | EXINT11 input source configuration<br>These bits are used to select the input source for the EXINT11 external interrupt.<br>0000: GPIOA pin 11<br>0001: GPIOB pin 11<br>0010: GPIOC pin 11<br>0101: GPIOF pin 11<br>Others: Reserved |
| Bit 11:8  | EXINT10  | 0x0         | rw   | EXINT10 input source configuration<br>These bits are used to select the input source for the EXINT10 external interrupt.<br>0000: GPIOA pin 10<br>0001: GPIOB pin 10<br>0010: GPIOC pin 10<br>Others: Reserved                       |
| Bit 7:4   | EXINT9   | 0x0         | rw   | EXINT9 input source configuration<br>These bits are used to select the input source for the EXINT9 external interrupt.<br>0000: GPIOA pin 9<br>0001: GPIOB pin 9<br>0010: GPIOC pin 9<br>Others: Reserved                            |
| Bit 3:0   | EXINT8   | 0x0         | rw   | EXINT8 input source configuration                                                                                                                                                                                                    |

These bits are used to select the input source for the EXINT8 external interrupt.  
 0000: GPIOA pin 8  
 0001: GPIOB pin 8  
 0010: GPIOC pin 8  
 Others: Reserved

## 7.2.6 SCFG external interrupt configuration register 4 (SCFG\_EXINTC4)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                     |
| Bit 15:12 | EXINT15  | 0x0         | rw   | EXINT15 input source configuration<br>These bits are used to select the input source for the EXINT15 external interrupt.<br>0000: GPIOA pin 15<br>0001: GPIOB pin 15<br>0010: GPIOC pin 15<br>Others: Reserved |
| Bit 11:8  | EXINT14  | 0x0         | rw   | EXINT14 input source configuration<br>These bits are used to select the input source for the EXINT14 external interrupt.<br>0000: GPIOA pin 14<br>0001: GPIOB pin 14<br>0010: GPIOC pin 14<br>Others: Reserved |
| Bit 7:4   | EXINT13  | 0x0         | rw   | EXINT13 input source configuration<br>These bits are used to select the input source for the EXINT13 external interrupt.<br>0000: GPIOA pin 13<br>0001: GPIOB pin 13<br>0010: GPIOC pin 13<br>Others: Reserved |
| Bit 3:0   | EXINT12  | 0x0         | rw   | EXINT12 input source configuration<br>These bits are used to select the input source for the EXINT12 external interrupt.<br>0000: GPIOA pin 12<br>0001: GPIOB pin 12<br>0010: GPIOC pin 12<br>Others: Reserved |

## 7.2.7 SCFG ultra high sourcing/sinking strength register (SCFG\_UHDRV)

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                   |
|----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:3 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                    |
| Bit 2    | PB10_UH  | 0x0         | rw   | PB10 Ultra high sourcing/sinking strength<br>This bit is written by software to control PB10 PAD sourcing/sinking strength.<br>0: Not active<br>1: Corresponding GPIO is switched to ultra high sourcing/sinking strength<br>When this bit is set, the control bits of GPIOx_ODRVR&GPIOx_HDRV become invalid. |
| Bit 1    | PB9_UH   | 0x0         | rw   | PB9 Ultra high sourcing/sinking strength<br>This bit is written by software to control PB9 PAD sourcing/sinking strength.<br>0: Not active<br>1: Corresponding GPIO is switched to ultra high sourcing/sinking strength<br>When this bit is set, the control bits of GPIOx_ODRVR&GPIOx_HDRV becomes invalid.  |
| Bit 0    | PB3_UH   | 0x0         | rw   | PB3 Ultra high sourcing/sinking strength<br>This bit is written by software to control PB3 PAD sourcing/sinking strength.<br>0: Not active<br>1: Corresponding GPIO is switched to ultra high sourcing/sinking strength<br>When this bit is set, the control bits of GPIOx_ODRVR&GPIOx_HDRV becomes invalid.  |

# 8 External interrupt/event controller (EXINT)

## 8.1 EXINT introduction

EXINT consists of 22 interrupt lines EXINT\_LINE[22:0] (in which bit [19] is reserved), each of which can generate an interrupt or event by edge detection trigger or software trigger. EXINT can enable or disable an interrupt or event independently through software configuration, and utilizes different edge detection modes (rising edge, falling edge or both edges) as well as trigger modes (edge detection, software trigger or both triggers) to respond to trigger source in order to generate an interrupt or event.

Figure 8-1 External interrupt/event controller block diagram



### Main features:

- EXINT interrupt lines 0~15 mapping I/O can be configured independently
- Independent trigger selection on each interrupt line
- Independent enable bit for each interrupt
- Independent enable bit for each event
- Up to 22 software triggers that can be generated and cleared independently
- Independent status bit for each interrupt
- Each interrupt can be cleared independently

## 8.2 Function overview and configuration procedure

With up to 22 interrupt lines EXINT\_LINE[22:0] (in which bit [19] is reserved), EXINT can detect not only GPIO external interrupt sources but also six internal sources such as PVM output, ERTC alarm events, ERTC tamper and timestamp events, ERTC wakeup events, OTGFS wakeup events and OTGHS wakeup events through edge detection mechanism, where, GPIO interrupt sources can be selected with the SCFG\_EXINTCx register. It should be noted that these input sources are mutually exclusive. For example, EXINT\_LINE0 is allowed to select one of PA0/PB0/PC0/PD0 pins, instead of taking both PA0 and PB0 as the input sources at the same time.

EXINT supports multiple edge detection modes, including rising edge, falling edge or both edges, selected by EXINT\_POLCFG1 and EXINT\_POLCFG2 registers. Active edge trigger detected on the interrupt line can be used to generate an event or interrupt.

In addition, EXINT supports independent software trigger for the generation of an event or interrupt. This is achieved by setting the corresponding bits in the EXINT\_SWTRG register.

EXINT can enable or disable an interrupt or event individually through software configuration such as EXINT\_INTEN and EXINT\_EVTEN registers, indicating that the corresponding interrupt or event must be enabled prior to either edge detection or software trigger.

EXINT also features an independent interrupt status bit. Reading access to EXINT\_INTSTS register can obtain the corresponding interrupt status. The status flag is cleared by writing "1" to this register.

### Interrupt initialization procedure

- **Select an interrupt source** by setting the SCFG\_EXINTCx register (this is required when GPIO is used as an interrupt source);
- **Select a trigger mode** by setting the EXINT\_POLCFG1 and EXINT\_POLCFG2 registers;
- **Enable interrupt or event** by setting the EXINT\_INTEN or EXINT\_EVTEN register;
- **Generate software trigger** by setting the EXINT\_SWTRG register (this is applied to only software trigger interrupt).

*Note: To modify the interrupt source configuration, disable the EXINT\_INTEN and EXINT\_EVTEN registers and then restart interrupt initialization.*

#### Interrupt clear procedure

- Writing “1” to the EXINT\_INTSTS register to clear the interrupts generated, and the corresponding bits in the EXINT\_SWTRG register will be cleared at the same time.

## 8.3 EXINT registers

The table below shows EXINT register map and their reset value.

These peripheral registers must be accessed by words (32 bits).

Table 8-1 External interrupt/event controller register map and reset value

| Register      | Offset | Reset value |
|---------------|--------|-------------|
| EXINT_INTEN   | 0x00   | 0x0000 0000 |
| EXINT_EVTEN   | 0x04   | 0x0000 0000 |
| EXINT_POLCFG1 | 0x08   | 0x0000 0000 |
| EXINT_POLCFG2 | 0x0C   | 0x0000 0000 |
| EXINT_SWTRG   | 0x10   | 0x0000 0000 |
| EXINT_INTSTS  | 0x14   | 0x0000 0000 |

### 8.3.1 Interrupt enable register (EXINT\_INTEN)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                         |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:23 | Reserved | 0x000       | resd | Forced to 0 by hardware                                                                                                                             |
| Bit 22:0  | INTENx   | 0x000000    | rw   | Interrupt enable or disable on line x<br>0: Interrupt request is disabled<br>1: Interrupt request is enabled<br>Note: Bit [19] is reserved. Unused. |

### 8.3.2 Event enable register (EXINT\_EVTEN)

| Bit       | Name     | Reset value | Type | Description                                                                                                                             |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:23 | Reserved | 0x000       | resd | Forced to 0 by hardware                                                                                                                 |
| Bit 22:0  | EVTENx   | 0x000000    | rw   | Event enable or disable on line x<br>0: Event request is disabled<br>1: Event request is enabled<br>Note: Bit [19] is reserved. Unused. |

### 8.3.3 Polarity configuration register 1 (EXINT\_POLCFG1)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                   |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:23 | Reserved | 0x000       | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                       |
| Bit 22:0  | RPx      | 0x000000    | rw   | Rising polarity configuration bit of line x<br>These bits are used to select a rising edge to trigger an interrupt and event on line x.<br>0: Rising edge trigger on line x is disabled<br>1: Rising edge trigger on line x is enabled<br>Note: Bit [19] is reserved. Unused. |

### 8.3.4 Polarity configuration register 2 (EXINT\_POLCFG2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                             |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:23 | Reserved | 0x000       | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                 |
| Bit 22:0  | FRx      | 0x000000    | rw   | Falling polarity event configuration bit of line x<br>These bits are used to select a falling edge to trigger an interrupt and event on line x.<br>0: Falling edge trigger on line x is disabled<br>1: Falling edge trigger on line x is enabled<br>Note: Bit [19] is reserved. Unused. |

### 8.3.5 Software trigger register (EXINT\_SWTRG)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:23 | Reserved | 0x000       | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 22:0  | SWTx     | 0x000000    | rw   | <p>Software trigger on line x<br/>           If the corresponding bit in the EXINT_INTEN register is 1, the software writes this bit, and the hardware sets the corresponding bit in the EXINT_INTSTS register automatically to generate an interrupt.</p> <p>If the corresponding bit in the EXINT_EVTEN register is 1, the software writes this bit, and the hardware generates an event on the corresponding interrupt line automatically.</p> <p>0: Default value<br/>           1: Software trigger generated<br/>           Note: This bit is cleared by writing "1" to the corresponding bit in the EXINT_INTSTS register.<br/>           Note: Bit [19] is reserved. Unused.</p> |

### 8.3.6 Interrupt status register (EXINT\_INTSTS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                       |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:23 | Reserved | 0x000       | resd | Forced to 0 by hardware                                                                                                                                                                                           |
| Bit 22:0  | LINEx    | 0x000000    | rw1c | <p>Line x status bit<br/>           0: No interrupt occurred<br/>           1: Interrupt occurred<br/>           Note: This bit is cleared by writing "1".<br/>           Note: Bit [19] is reserved. Unused.</p> |

# 9 DMA controller (DMA)

## 9.1 Introduction

Direct memory access (DMA) controller is designed for high-speed data transmission between peripherals and memory or between memories. The data can be transmitted through DMA at a high speed without CPU interference, which saves CPU capacity.

There are two DMA controllers in the microcontroller. Each controller contains seven DMA channels that manage memory access requests from one or more peripherals. An arbiter is available for coordinating the priority of each DMA request.

## 9.2 Main features

- AMBA compliant (Rev. 2.0)
- Only support AHB OKAY and ERROR responses
- HBUSREQ and HGRANT of AHB master interface are not supported
- Support 7 channels
- Peripheral-to-memory, memory-to-peripheral, and memory-to-memory transfers
- Support hardware handshake
- Support 8-bit, 16-bit and 32-bit data transfers
- Programmable amount of data to be transferred: up to 65535
- Support multiplexing

Figure 9-1 DMA block diagram



Note: The number of DMA peripherals may be different for different models.

## 9.3 Function overview

### 9.3.1 DMA configuration

#### 1. Set the peripheral address in the DMA\_CPBAX register

The initial peripheral address for data transfer remains unchanged during transmission.

#### 2. Set the memory address in the DMA\_CMBAX register

The initial memory address for data transfer remains unchanged during transmission.

#### 3. Configure the amount of the data to be transferred in the DMA\_DTCNTx register

Programmable data transfer size is up to 65535. This value is decremented after each data transfer.

#### 4. Configure the channel setting in the DMA\_CHCTRLx register

Including channel priority, data transfer direction/width, address incremented mode, circular mode and interrupt mode

##### Channel priority (CHPL)

there are four levels, including very high priority, high priority, medium priority and low priority.

If the two channels have the same priority level, then the channel with lower number will get priority over the one with higher number. For example, channel 1 has priority over channel 2.

##### Data transfer direction (DTD)

Memory-to-peripheral (M2P) and peripheral-to-memory (P2M)

##### Address incremented mode (PINCM/MINCM)

In incremented mode, the subsequent transfer address is the previous address plus transfer width (PWIDHT/MWIDHT).

##### Circular mode (LM)

In circular mode, the contents in the DMA\_DTCNTx register is automatically reloaded with the initially programmed value after the completion of the last transfer

##### Memory-to-memory mode (M2M)

This mode indicates that DMA channels perform data transfer without requests from peripherals.

Circular mode and memory-to-memory mode cannot be used at the same time.

#### 5. Enable DMA transfer by setting the CHEN bit in the DMA\_CHCTRLx register

### 9.3.2 Handshake mechanism

In P2M and M2P mode, the peripherals need to send a request signal to the DMA controller. The DMA channel will send the peripheral transfer request (single) until the signal is acknowledged. After the completion of peripheral transmission, the DMA controller sends the acknowledge signal to the peripheral. The peripheral then releases its request as soon as it receives the acknowledge signal. At the same time, the DMA controller releases the acknowledge signal as well.

### 9.3.3 Arbiter

When several channels are enabled simultaneously, the arbiter will restart arbitration after full data transfer by the master controller. The channel with very high priority waits until the channel of the master controller has completed data transfers before taking control of it. The master controller will re-arbitrate to serve other channels as long as the channel completes a single transfer based on the master controller priority.

Figure 9-2 Re-arbitrate after request/acknowledge



### 9.3.4 Programmable data transfer width

Transfer width of the source data and destination data is programmable through the PWIDHT and MWIDTH bits in the DMA\_CHCTRLx register. When PWIDHT is not equal to MWIDTH, it can be aligned according to the settings of PWIDHT/ MWIDTH.

Figure 9-3 PWIDHT: byte, MWIDTH: half-word



Figure 9-4 PWIDHT: half-word, MWIDTH: word



Figure 9-5 PWIDHT: word, MWIDTH: byte



### 9.3.5 Errors

Table 9-1 DMA error event

| Error event    | Description                                              |
|----------------|----------------------------------------------------------|
| Transfer error | AHB response error occurred during DMA read/write access |

### 9.3.6 Interrupts

An interrupt can be generated on a DMA half-transfer, transfer complete and transfer error. Each channel has its specific interrupt flag, clear and enable bits, as shown in the table below.

Table 9-2 DMA interrupts

| Interrupt event    | Event flag bit | Clear control bit | Enable control bit |
|--------------------|----------------|-------------------|--------------------|
| Half-transfer      | HDTF           | HDTFC             | HDTIEN             |
| Transfer completed | FDTF           | FDTFC             | FDTIEN             |
| Transfer error     | DTERRF         | DTERRFC           | DTERRIEN           |

## 9.4 DMA multiplexer (DMAMUX)

DMAMUX manages DMA requests/acknowledge between peripherals and DMA controller.

The DMA controller selects the DMA mapping table with the TBL\_SEL bit in the DMA\_MUXSEL register. Each DMA controller stream selects only one DMA request from the flexible mapping table. In flexible mapping mode, each channel can bypass or synchronize 127 possible channel requests from peripherals or generators through the REQSEL [6:0] bit in the DMA\_MUXCxCTRL register.

### 9.4.1 DMAMUX function overview

The DMAMUX consists of a request generator and a request multiplexer.

Each of the DMAMUX generator channel  $x$  has a GEN enable bit in the DMA\_MUXGxCTRL register. The SIGSEL bit is used to select the trigger input of the DMAMUX generator. Typically, the number of DMA requests equals GREQCNT + 1. The GPOL bit in the DMA\_MUXGxCTRL register is used to select a trigger event that can be on a rising edge, falling edge or either of them.

Each of the DMAMUX stream  $x$  comes from all\_req [127:1].

In flexible mapping mode, the SYNCEN bit in the DMA\_MUXSxCTRL register is used to synchronize the selected DMA request input. In synchronous mode, the SYNCSEL bit in the DMA\_MUXSxCTRL register is used to select synchronized input. The selected DMA request input will be transferred to chx\_mux\_req [7:0] as soon as a valid edge of the synchronized input is detected by the SYNCPOL [1:0] in the DMA\_MUXSxCTRL register. In addition, when the EVTGEN bit in the DMA\_MUXCxCTRL register is set, the programmable request counter (REQCNT) is used to generate a request output and event output.

Figure 9-6 DMAMUX block diagram



Table 9-3 Flexible DMA1 / DMA2 request mapping

| CHx_SRC | Request source |
|---------|----------------|---------|----------------|---------|----------------|---------|----------------|
| 1       | DMA_MUXREQG1   | 33      | USART5_TX      | 65      | TMR3_OVERFLOW  | 97      | reserved       |
| 2       | DMA_MUXREQG2   | 34      | reserved       | 66      | TMR3_TRIG      | 98      | reserved       |
| 3       | DMA_MUXREQG3   | 35      | reserved       | 67      | TMR4_CH1       | 99      | reserved       |
| 4       | DMA_MUXREQG4   | 36      | reserved       | 68      | TMR4_CH2       | 100     | reserved       |
| 5       | ADC1           | 37      | reserved       | 69      | TMR4_CH3       | 101     | reserved       |
| 6       | reserved       | 38      | reserved       | 70      | TMR4_CH4       | 102     | reserved       |
| 7       | reserved       | 39      | reserved       | 71      | TMR4_OVERFLOW  | 103     | reserved       |
| 8       | TMR6_OVERFLOW  | 40      | QSPI1          | 72      | reserved       | 104     | reserved       |
| 9       | TMR7_OVERFLOW  | 41      | reserved       | 73      | reserved       | 105     | reserved       |
| 10      | SPI1_RX        | 42      | TMR1_CH1       | 74      | reserved       | 106     | reserved       |
| 11      | SPI1_TX        | 43      | TMR1_CH2       | 75      | reserved       | 107     | reserved       |
| 12      | SPI2_RX        | 44      | TMR1_CH3       | 76      | reserved       | 108     | I2SF5_RX       |
| 13      | SPI2_TX        | 45      | TMR1_CH4       | 77      | reserved       | 109     | I2S_TX         |
| 14      | SPI3_RX        | 46      | TMR1_OVERFLOW  | 78      | TMR9_CH1       | 110     | reserved       |
| 15      | SPI3_TX        | 47      | TMR1_TRIG      | 79      | TMR9_OVERFLOW  | 111     | reserved       |
| 16      | I2C1_RX        | 48      | TMR1_HALL      | 80      | TMR9_TRIG      | 112     | reserved       |
| 17      | I2C1_TX        | 49      | reserved       | 81      | TMR9_HALL      | 113     | reserved       |
| 18      | I2C2_RX        | 50      | reserved       | 82      | TMR10_CH1      | 114     | USART6_RX      |
| 19      | I2C2_TX        | 51      | reserved       | 83      | TMR10_OVERFLOW | 115     | USART6_TX      |
| 20      | I2C3_RX        | 52      | reserved       | 84      | TMR11_CH1      | 116     | USART7_RX      |
| 21      | I2C3_TX        | 53      | reserved       | 85      | TMR11_OVERFLOW | 117     | USART7_TX      |
| 22      | reserved       | 54      | reserved       | 86      | reserved       | 118     | USART8_RX      |
| 23      | reserved       | 55      | reserved       | 87      | reserved       | 119     | USART8_TX      |
| 24      | USART1_RX      | 56      | TMR2_CH1       | 88      | reserved       | 120     | TMR13_CH1      |
| 25      | USART1_TX      | 57      | TMR2_CH2       | 89      | reserved       | 121     | TMR13_OVERFLOW |
| 26      | USART2_RX      | 58      | TMR2_CH3       | 90      | reserved       | 122     | TMR14_CH1      |
| 27      | USART2_TX      | 59      | TMR2_CH4       | 91      | reserved       | 123     | TMR14_OVERFLOW |
| 28      | USART3_RX      | 60      | TMR2_OVERFLOW  | 92      | reserved       | 124     | TMR9_CH2       |
| 29      | USART3_TX      | 61      | TMR3_CH1       | 93      | reserved       | 125     | reserved       |
| 30      | USART4_RX      | 62      | TMR3_CH2       | 94      | reserved       | 126     | TMR2_TRIG      |
| 31      | USART4_TX      | 63      | TMR3_CH3       | 95      | reserved       | 127     | TMR4_TRIG      |
| 32      | USART5_RX      | 64      | TMR3_CH4       | 96      | reserved       |         |                |

Table 9-4 DMAMUX EXINT LINE for trigger input and synchronized input

| EXINT LINE | Source        | EXINT LINE | Source         | EXINT LINE | Source      | EXINT LINE | Source   |
|------------|---------------|------------|----------------|------------|-------------|------------|----------|
| 0          | exint_gpio[0] | 8          | exint_gpio[8]  | 16         | DMA_MUXevt1 | 24         | reserved |
| 1          | exint_gpio[1] | 9          | exint_gpio[9]  | 17         | DMA_MUXevt2 | 25         | reserved |
| 2          | exint_gpio[2] | 10         | exint_gpio[10] | 18         | DMA_MUXevt3 | 26         | reserved |
| 3          | exint_gpio[3] | 11         | exint_gpio[11] | 19         | DMA_MUXevt4 | 27         | reserved |
| 4          | exint_gpio[4] | 12         | exint_gpio[12] | 20         | DMA_MUXevt5 | 28         | reserved |
| 5          | exint_gpio[5] | 13         | exint_gpio[13] | 21         | DMA_MUXevt6 | 39         | reserved |
| 6          | exint_gpio[6] | 14         | exint_gpio[14] | 22         | DMA_MUXevt7 | 30         | reserved |
| 7          | exint_gpio[7] | 15         | exint_gpio[15] | 23         | reserved    | 31         | reserved |

## 9.4.2 DMAMUX overflow interrupts

During DMAMUX request generation, when a new trigger input occurs before the GREQCNT underflows, the TRGOVFX bit will be set in the DMA\_MUXGSTS register. It is cleared by setting TRGOVFCx=1 in the DMA\_MUXGCLR register. An interrupt will be generated if the interrupt enable bit TRGOVIEN is set in the DMA\_MUXGxCTRL register.

In DMAMUX synchronous mode, when a new synchronized input occurs before the REQCNT underflows, the SYNCOVFX bit will be set in the DMA\_MUXSYNCSTS register. It is cleared by setting SYNCOVFCx=1 in the DMA\_MUXSYNCCLR register. An interrupt will be generated if the interrupt enable bit SYNCOVIEN is set in the DMA\_MUXSxCTRL register.

Figure 9-7 DMAMUX request synchronized mode



Figure 9-8 DMAMUX event generation



## 9.5 DMA registers

The table below lists DMA register map and their reset values. These peripheral registers can be accessed by bytes (8 bits), half-words (16 bits) or words (32 bits).

Table 9-5 DMA register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| DMA_STS     | 0x00   | 0x0000 0000 |
| DMA_CLR     | 0x04   | 0x0000 0000 |
| DMA_C1CTRL  | 0x08   | 0x0000 0000 |
| DMA_C1DTCNT | 0x0c   | 0x0000 0000 |
| DMA_C1PADDR | 0x10   | 0x0000 0000 |
| DMA_C1MADDR | 0x14   | 0x0000 0000 |
| DMA_C2CTRL  | 0x1c   | 0x0000 0000 |
| DMA_C2DTCNT | 0x20   | 0x0000 0000 |
| DMA_C2PADDR | 0x24   | 0x0000 0000 |
| DMA_C2MADDR | 0x28   | 0x0000 0000 |
| DMA_C3CTRL  | 0x30   | 0x0000 0000 |
| DMA_C3DTCNT | 0x34   | 0x0000 0000 |
| DMA_C3PADDR | 0x38   | 0x0000 0000 |
| DMA_C3MADDR | 0x3c   | 0x0000 0000 |
| DMA_C4CTRL  | 0x44   | 0x0000 0000 |
| DMA_C4DTCNT | 0x48   | 0x0000 0000 |
| DMA_C4PADDR | 0x4c   | 0x0000 0000 |
| DMA_C4MADDR | 0x50   | 0x0000 0000 |
| DMA_C5CTRL  | 0x58   | 0x0000 0000 |
| DMA_C5DTCNT | 0x5c   | 0x0000 0000 |
| DMA_C5PADDR | 0x60   | 0x0000 0000 |
| DMA_C5MADDR | 0x64   | 0x0000 0000 |
| DMA_C6CTRL  | 0x6c   | 0x0000 0000 |
| DMA_C6DTCNT | 0x70   | 0x0000 0000 |

|                 |       |             |
|-----------------|-------|-------------|
| DMA_C6PADDR     | 0x74  | 0x0000 0000 |
| DMA_C6MADDR     | 0x78  | 0x0000 0000 |
| DMA_C7CTRL      | 0x80  | 0x0000 0000 |
| DMA_C7DTCNT     | 0x84  | 0x0000 0000 |
| DMA_C7PADDR     | 0x88  | 0x0000 0000 |
| DMA_C7MADDR     | 0x8c  | 0x0000 0000 |
| DMA_MUXSEL      | 0x100 | 0x0000 0000 |
| DMA_MUXC1CTRL   | 0x104 | 0x0000 0000 |
| DMA_MUXC2CTRL   | 0x108 | 0x0000 0000 |
| DMA_MUXC3CTRL   | 0x10c | 0x0000 0000 |
| DMA_MUXC4CTRL   | 0x110 | 0x0000 0000 |
| DMA_MUXC5CTRL   | 0x114 | 0x0000 0000 |
| DMA_MUXC6CTRL   | 0x118 | 0x0000 0000 |
| DMA_MUXC7CTRL   | 0x11c | 0x0000 0000 |
| DMA_MUXG1CTRL   | 0x120 | 0x0000 0000 |
| DMA_MUXG2CTRL   | 0x124 | 0x0000 0000 |
| DMA_MUXG3CTRL   | 0x128 | 0x0000 0000 |
| DMA_MUXG4CTRL   | 0x12c | 0x0000 0000 |
| DMA_MUXSYNCSTS  | 0x130 | 0x0000 0000 |
| DMA_MUXSYNCCCLR | 0x134 | 0x0000 0000 |
| DMA_MUXGSTS     | 0x138 | 0x0000 0000 |
| DMA_MUXGCLR     | 0x13c | 0x0000 0000 |

### 9.5.1 DMA interrupt status register (DMA\_STS)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                      |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:28 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                       |
| Bit 27    | DTERRF7  | 0x0         | ro   | Channel 7 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |
| Bit 26    | HDTF7    | 0x0         | ro   | Channel 7 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 25    | FDTF7    | 0x0         | ro   | Channel 7 transfer complete event flag<br>0: No transfer complete event occurred<br>1: Transfer complete event occurred                          |
| Bit 24    | GF7      | 0x0         | ro   | Channel 7 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |
| Bit 23    | DTERRF6  | 0x0         | ro   | Channel 6 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |
| Bit 22    | HDTF6    | 0x0         | ro   | Channel 6 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 21    | FDTF6    | 0x0         | ro   | Channel 6 transfer complete event flag<br>0: No transfer complete event occurred<br>1: Transfer complete event occurred                          |
| Bit 20    | GF6      | 0x0         | ro   | Channel 6 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |
| Bit 19    | DTERRF5  | 0x0         | ro   | Channel 5 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |
| Bit 18    | HDTF5    | 0x0         | ro   | Channel 5 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 17    | FDTF5    | 0x0         | ro   | Channel 5 transfer complete event flag<br>0: No transfer complete event occurred<br>1: Transfer complete event occurred                          |
| Bit 16    | GF5      | 0x0         | ro   | Channel 5 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |
| Bit 15    | DTERRF4  | 0x0         | ro   | Channel 4 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |

|        |         |     |    |                                                                                                                                                  |
|--------|---------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 14 | HDTF4   | 0x0 | ro | Channel 4 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 13 | FDTF4   | 0x0 | ro | Channel 4 transfer complete event flag<br>0:No transfer complete event occurred<br>1:Transfer complete event occurred                            |
| Bit 12 | GF4     | 0x0 | ro | Channel 4 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |
| Bit 11 | DTERRF3 | 0x0 | ro | Channel 3 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |
| Bit 10 | HDTF3   | 0x0 | ro | Channel 3 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 9  | FDTF3   | 0x0 | ro | Channel 3 transfer complete event flag<br>0:No transfer complete event occurred<br>1:Transfer complete event occurred                            |
| Bit 8  | GF3     | 0x0 | ro | Channel 3 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |
| Bit 7  | DTERRF2 | 0x0 | ro | Channel 2 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |
| Bit 6  | HDTF2   | 0x0 | ro | Channel 2 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 5  | FDTF2   | 0x0 | ro | Channel 2 transfer complete event flag<br>0:No transfer complete event occurred<br>1:Transfer complete event occurred                            |
| Bit 4  | GF2     | 0x0 | ro | Channel 2 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |
| Bit 3  | DTERRF1 | 0x0 | ro | Channel 1 data transfer error event flag<br>0: No transfer error occurred<br>1: Transfer error occurred                                          |
| Bit 2  | HDTF1   | 0x0 | ro | Channel 1 half transfer event flag<br>0: No half-transfer event occurred<br>1: Half-transfer event occurred                                      |
| Bit 1  | FDTF1   | 0x0 | ro | Channel 1 transfer complete event flag<br>0:No transfer complete event occurred<br>1:Transfer complete event occurred                            |
| Bit 0  | GF1     | 0x0 | ro | Channel 1 global event flag<br>0: No transfer error, half-transfer or transfer complete<br>1: Transfer error, half-transfer or transfer complete |

## 9.5.2 DMA interrupt flag clear register (DMA\_CLR)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit       | Name     | Reset value | Type | Description                                                                                                         |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 31:28 | Reserved | 0x0         | resd | Kept at its default value.                                                                                          |
| Bit 27    | DTERRFC7 | 0x0         | rw1c | Channel 7 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF7 flag in the DMA_STS register       |
| Bit 26    | HDTFC7   | 0x0         | rw1c | Channel 7 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF7 flag DMA_STS register                      |
| Bit 25    | FDTFC7   | 0x0         | rw1c | Channel 7 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF7 flag in the DMA_STS register           |
| Bit 24    | GFC7     | 0x0         | rw1c | Channel 7 global flag clear<br>0: No effect<br>1: Clear DTERRF7, HDTF7, FDTF7 and GF7 flags in the DMA_STS register |
| Bit 23    | DTERRFC6 | 0x0         | rw1c | Channel 6 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF6 flag in the DMA_STS register       |
| Bit 22    | HDTFC6   | 0x0         | rw1c | Channel 6 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF6 flag in the DMA_STS register               |
| Bit 21    | FDTFC6   | 0x0         | rw1c | Channel 6 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF6 flag in the DMA_STS register           |
| Bit 20    | GFC6     | 0x0         | rw1c | Channel 6 global flag clear<br>0: No effect<br>1: Clear DTERRF6, HDTF6, FDTF6 and GF6 flags in the DMA_STS register |
| Bit 19    | DTERRFC5 | 0x0         | rw1c | Channel 5 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF5 flag in the DMA_STS register       |
| Bit 18    | HDTFC5   | 0x0         | rw1c | Channel 5 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF5 flag in the DMA_STS register               |
| Bit 17    | FDTFC5   | 0x0         | rw1c | Channel 5 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF5 flag in the DMA_STS register           |
| Bit 16    | GFC5     | 0x0         | rw1c | Channel 5 global flag clear<br>0: No effect<br>1: Clear DTERRF5, HDTF5, FDTF5 and GF5 flags in the DMA_STS register |
| Bit 15    | DTERRFC4 | 0x0         | rw1c | Channel 4 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF4 flag in the DMA_STS register       |

|        |          |     |      |                                                                                                                        |
|--------|----------|-----|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 14 | HDTFC4   | 0x0 | rw1c | Channel 4 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF4 flag in the DMA_STS register                  |
| Bit 13 | FDTFC4   | 0x0 | rw1c | Channel 4 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF4 flag in the DMA_STS register              |
| Bit 12 | GFC4     | 0x0 | rw1c | Channel 4 global flag clear<br>0: No effect<br>1: Clear DTERRF4, HDTF4, FDTF4 and GF4 flags in the DMA_STS register    |
| Bit 11 | DTERRFC3 | 0x0 | rw1c | Channel 3 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF3 flag in the DMA_STS register          |
| Bit 10 | HDTFC3   | 0x0 | rw1c | Channel 3 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF3 flag in the DMA_STS register                  |
| Bit 9  | FDTFC3   | 0x0 | rw1c | Channel 3 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF3 flag in the DMA_STS register              |
| Bit 8  | GFC3     | 0x0 | rw1c | Channel 3 global flag clear<br>0: No effect<br>1: Clear DTERRF3, HDTF3, FDTF3 and GF3 flags in the DMA_STS register    |
| Bit 7  | DTERRFC2 | 0x0 | rw1c | Channel 2 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF2 flag in the DMA_STS register          |
| Bit 6  | HDTFC2   | 0x0 | rw1c | Channel 2 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF2 flag in the DMA_STS register                  |
| Bit 5  | FDTFC2   | 0x0 | rw1c | Channel 2 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF2 flag in the DMA_STS register              |
| Bit 4  | GFC2     | 0x0 | rw1c | Channel 2 global flag clear<br>0: No effect<br>1: Clear DTERRF2 and HDTF2, FDTF2 and GF2 flags in the DMA_STS register |
| Bit 3  | DTERRFC1 | 0x0 | rw1c | Channel 1 data transfer error flag clear<br>0: No effect<br>1: Clear the DTERRF1 flag in the DMA_STS register          |
| Bit 2  | HDTFC1   | 0x0 | rw1c | Channel 1 half transfer flag clear<br>0: No effect<br>1: Clear the HDTF1 flag in the DMA_STS register                  |
| Bit 1  | FDTFC1   | 0x0 | rw1c | Channel 1 transfer complete flag clear<br>0: No effect<br>1: Clear the FDTF1 flag in the DMA_STS register              |

---

|       |      |     |      |                                                                                                                     |
|-------|------|-----|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 0 | GFC1 | 0x0 | rw1c | Channel 1 global flag clear<br>0: No effect<br>1: Clear DTERRF1, HDTF1, FDTF1 and GF1 flags in the DMAISTS register |
|-------|------|-----|------|---------------------------------------------------------------------------------------------------------------------|

---

### 9.5.3 DMA channel-x configuration register (DMA\_CxCTRL) (x=1...7)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit       | Name     | Reset value | Type | Description                                                                           |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------|
| Bit 31:15 | Reserved | 0x00000     | resd | Kept at its default value.                                                            |
| Bit 14    | M2M      | 0x0         | rw   | Memory-to-memory mode<br>0: Disabled<br>1: Enabled                                    |
| Bit 13:12 | CHPL     | 0x0         | rw   | Channel priority level<br>00: Low<br>01: Medium<br>10: High<br>11: Very high          |
| Bit 11:10 | MWIDTH   | 0x0         | rw   | Memory data bit width<br>00: 8 bits<br>01: 16 bits<br>10: 32 bits<br>11: Reserved     |
| Bit 9:8   | PWIDTH   | 0x0         | rw   | Peripheral data bit width<br>00: 8 bits<br>01: 16 bits<br>10: 32 bits<br>11: Reserved |
| Bit 7     | MINCM    | 0x0         | rw   | Memory address increment mode<br>0: Disabled<br>1: Enabled                            |
| Bit 6     | PINCM    | 0x0         | rw   | Peripheral address increment mode<br>0: Disabled<br>1: Enabled                        |
| Bit 5     | LM       | 0x0         | rw   | Circular mode<br>0: Disabled<br>1: Enabled                                            |
| Bit 4     | DTD      | 0x0         | rw   | Data transfer direction<br>0: Read from peripherals<br>1: Read from memory            |
| Bit 3     | DTERRIEN | 0x0         | rw   | Data transfer error interrupt enable<br>0: Disabled<br>1: Enabled                     |
| Bit 2     | HDTIEN   | 0x0         | rw   | Half transfer interrupt enable<br>0: Disabled<br>1: Enabled                           |
| Bit 1     | FDTIEN   | 0x0         | rw   | Transfer complete interrupt enable<br>0: Disabled<br>1: Enabled                       |
| Bit 0     | CHEN     | 0x0         | rw   | Channel enable<br>0: Disabled<br>1: Enabled                                           |

### 9.5.4 DMA channel-x number of data register (DMA\_CxDTCNT) (x=1...7)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                  |
| Bit 15:0  | CNT      | 0x0000      | rw   | <p>Number of data to transfer<br/>The number of data to transfer is from 0x0 to 0xFFFF. This register can only be written when CHEN=0 in the corresponding channel register. The value is decremented after each DMA transfer.</p> <p>Note: This register holds the number of data to transfer instead of transfer size. The transfer size is calculated by data width.</p> |

### 9.5.5 DMA channel-x peripheral address register (DMA\_CxPADDR) (x=1...7)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit      | Name  | Reset value | Type | Description                                                                                                                                                                                                                         |
|----------|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | PADDR | 0x0000 0000 | rw   | <p>Peripheral base address<br/>Base address of peripheral data register is the source or destination of data transfer.</p> <p>Note: The register can only be written when the CHEN=0 bit in the corresponding channel register.</p> |

### 9.5.6 DMA channel-x memory address register (DMA\_CxMADDR) (x=1...7)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit      | Name  | Reset value | Type | Description                                                                                                                                                                                           |
|----------|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | MADDR | 0x0000 0000 | rw   | <p>Memory base address<br/>Memory address is the source or destination of data transfer.</p> <p>Note: The register can only be written when the CHEN=0 bit in the corresponding channel register.</p> |

### 9.5.7 DMAMUX select register (DMA\_MUXSEL)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit   | Name     | Reset value | Type | Description                                             |
|-------|----------|-------------|------|---------------------------------------------------------|
| 31:1  | Reserved | 0x0000 0000 | resd | Kept at its default value.                              |
| Bit 0 | TBL_SEL  | 0x0         | rw   | Multiplexer table select<br>0x1: Flexible mapping table |

## 9.5.8 DMAMUX channel-x control register (DMA\_MUXCxCTRL) (x=1...7)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                      |
|-----------|-----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:25 | Reserved  | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                       |
| Bit 28:24 | SYNCSEL   | 0x00        | rw   | Synchronization select                                                                                                                                                                                                                                           |
| Bit 23:19 | REQCNT    | 0x00        | rw   | DMA request count<br>These bits indicate the number of DMA requests sent to the DMA controller after synchronization is enabled, and/or DMA request count before event output is generated.<br>These bits are reserved when both SYNCEN and EVTGEN bits are LOW. |
| Bit 18:17 | SYNCPOL   | 0x0         | rw   | Synchronization polarity<br>It is used to define the polarity of the selected synchronization input.<br>0x0: No event<br>0x1: Rising edge<br>0x2: Falling edge<br>0x3: Rising edge and falling edge                                                              |
| Bit 16    | SYNCEN    | 0x0         | rw   | Synchronization enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                              |
| Bit 15:10 | Reserved  | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                       |
| Bit 9     | EVTGEN    | 0x0         |      | Event generate enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                               |
| Bit 8     | SYNCOVIEN | 0x0         |      | Synchronization overrun interrupt enable<br>0: Interrupt disabled<br>1: Interrupt enabled                                                                                                                                                                        |
| Bit 7     | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                       |
| Bit 6:0   | REQSEL    | 0x00        |      | DMA request select<br>It is used to select the input DMA request. Refer to the DMAMUX table for the configuration of multiplexer input.                                                                                                                          |

### 9.5.9 DMAMUX generator-x control register (DMA\_MUXGxCTRL) (x=1...4)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                      |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                       |
| Bit 23:19 | GREQCNT  | 0x00        | rw   | DMA request generation count<br>It is used to define the number of DMA request (GNBREQ + 1 ) to be generated after trigger event.<br>This field is reserved only when the GEN bit is disabled.   |
| Bit 18:17 | GPOL     | 0x0         | rw   | DMA request generation polarity<br>This field defines the polarity of the selected trigger input.<br>0x0: No event<br>0x1: Rising edge<br>0x2: Falling edge<br>0x3: Rising edge and falling edge |
| Bit 16    | GEN      | 0x0         | rw   | DMA request generation enable<br>0: Disabled<br>1: Enabled                                                                                                                                       |
| Bit 15:9  | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                       |
| Bit 8     | TRGOVIEN | 0x0         | rw   | Trigger overrun interrupt enable<br>0: Interrupt disabled<br>1: Interrupt enabled                                                                                                                |
| Bit 7:5   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                       |
| Bit 4:0   | SIGSEL   | 0x00        | rw   | Signal select<br>It is used to select the DMA trigger input for DMA request generator.                                                                                                           |

### 9.5.10 DMAMUX channel synchronization status register (DMA\_MUXSYNCSTS)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                                                    |
|----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:7 | Reserved | 0x0000 00   | resd | Kept at its default value.                                                                                                                                                                     |
| Bit 6:0  | SYNCOVF  | 0x00        | ro   | Synchronization overrun interrupt flag<br>The synchronization overrun interrupt occurs when the DMA request counter is below REQCNT. This flag is set when a new synchronization event occurs. |

### 9.5.11 DMAMUX channel interrupt flag clear register (DMA\_MUXSYNCCLR)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit      | Name     | Reset value | Type | Description                                                                                                                               |
|----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:7 | Reserved | 0x0000 00   | resd | Kept at its default value.                                                                                                                |
| Bit 6:0  | SYNCOVFC | 0x00        | rw1c | Synchronization overrun interrupt flag clear<br>Writing 1 to the corresponding bit can clear the SYNCOVF flag in the MUXSYNCSTS register. |

### 9.5.12 DMAMUX generator interrupt status register (DMA\_MUXGSTS)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit      | Name     | Reset value | Type | Description                                                                                                                             |
|----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:4 | Reserved | 0x0000 000  | resd | Kept at its default value.                                                                                                              |
| Bit 3:0  | TRGOVF   | 0x00        | ro   | Trigger overrun interrupt flag<br>When the DMA request count is lower than GREQCNT, this field is set while a new trigger event occurs. |

### 9.5.13 DMAMUX generator interrupt flag clear register (DMA\_MUXGCLR)

Access: 0 wait state, accessible by bytes, half-words or words.

| Bit      | Name     | Reset value | Type | Description                                                                                                                       |
|----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:4 | Reserved | 0x0000 000  | resd | Kept at its default value.                                                                                                        |
| Bit 3:0  | TRGOVFC  | 0x00        | rw1c | Trigger overrun interrupt flag clear<br>Writing 1 to the corresponding bit can clear the TRGOVF flag in the DMA_MUXGSTS register. |

# 10 CRC calculation unit (CRC)

## 10.1 CRC introduction

The Cyclic Redundancy Check (CRC) is an independent peripheral with CRC check feature. It follows CRC-32/MPEG-2 standard.

The CRC\_CTRL register is used to select output data toggle (word, REVOD=1) or input data toggle (byte, REVID=01; half-word, REVID=10; word, REVID=11). The CRC calculation unit also has initialization function. After each CRC reset, the value in the CRC\_IDT register is written into the CRC\_DT register by CRC. The CRC\_POLY register can be used to program the polynomial coefficient, and the polynomial size can be set to 7-bit, 8-bit, 16-bit or 32-bit by setting the POLY\_SIZE bit in the CRC\_CTRL register.

Users can write the data to go through CRC check and read the calculated result through CRC\_DT register. Note that the calculation result is the combination of the previous result and the current value to be calculated.

Figure10-1 CRC calculation unit block diagram



### Main features:

- Use CRC-32 code
- Programmable polynomial
- 4 x HCLK cycles for each CRC calculation
- Support input/output data format toggle
- Perform write/read operation through CRC\_DT register
- Set an initialization value with the CRC\_IDT register. The value is loaded into CRC\_DT register after each CRC reset.

## 10.2 CRC function description

In CRC calculation, the input data is used as the dividend and the generating polynomial as the divisor for Modulo-2 Division, and the remainder obtained is the CRC value.

### CRC calculation procedure

- Toggle input, that is, toggle the input data according to the REVID value in the CRC\_CTRL register.
- Initialize: perform XOR with the initial value set in the CRC\_IDT for the first time of calculation (if it is not the first time, the initial value should be the previously calculated result).
- CRC calculation: perform Modulo-2 Division with the generating polynomial (0x4C11DB7), and the remainder obtained is the CRC value.

- Toggle output: determine whether to perform toggle (word) according to the REVOD value in the CRC\_CTRL register before output.
- Perform XOR calculation for the result, and the XOR-ed value is fixed to 0x0000 0000.

#### CRC-32/MPEG-2 parameters

- Generating polynomial: 0x4C11DB7,  

$$X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$$
- Initial value is 0xFFFF FFFF to avoid obtaining the same calculation result for 1-byte 0x00 and multibyte 0x00.
- XOR-ed value: 0x0000 0000, indicating the CRC result does not require an additional XOR calculation.

#### Toggle function

- Select byte toggle: 8 bits as a group and in reverse order. As shown in the figure below, if the original data is 0x12345678, the toggled data is 0x482C6A1E.
- Select half-word toggle: 16 bits as a group and in reverse order.
- Select word toggle: 32 bits as a group and in reverse order.

Figure 10-2 Example of byte toggle



## 10.3 CRC registers

Table 10-1 CRC register map and reset value

| Register | Offset | Reset value |
|----------|--------|-------------|
| CRC_DT   | 0x00   | 0xFFFF FFFF |
| CRC_CDT  | 0x04   | 0x0000 0000 |
| CRC_CTRL | 0x08   | 0x0000 0000 |
| CRC_IDT  | 0x10   | 0xFFFF FFFF |
| CRC_POLY | 0x14   | 0x04C1 1DB7 |

### 10.3.1 Data register (CRC\_DT)

| Bit      | Name | Reset value | Type | Description                                                                                                                                   |
|----------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | DT   | 0xFFFF FFFF | rw   | Data value<br>It is used as input register when writing new data into the CRC calculator. It returns CRC calculation results when it is read. |

### 10.3.2 Common data register (CRC\_CDT)

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                                         |
|----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:8 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                          |
| Bit 7:0  | CDT      | 0x00        | rw   | Common 8-bit data value<br>This field is used to store one byte data temporarily. This register is not affected by the CRC reset generated by the RST bit in the CRC_CTRL register. |

### 10.3.3 Control register (CRC\_CTRL)

| Bit      | Name      | Reset value | Type | Description                                                                                                                                                                                       |
|----------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:8 | Reserved  | 0x000000    | resd | Kept at its default value.                                                                                                                                                                        |
| Bit 7    | REVOD     | 0x0         | resd | Reverse output data<br>It is set and cleared by software. This bit is used to control whether or not to reverse output data.<br>0: No effect<br>1: Word reverse                                   |
| Bit 6:5  | REVID     | 0x0         | rw   | Reverse input data<br>It is set and cleared by software. This bit is used to control how to reverse input data.<br>00: No effect<br>01: Byte reverse<br>10: Half-word reverse<br>11: Word reverse |
| Bit 4:3  | POLY_SIZE | 0x0         | rw   | Polynomial size<br>This bit is used to set the polynomial size. It works with the CRC_POLY register.<br>00: 32-bit<br>01: 16-bit<br>10: 8-bit<br>11: 7-bit                                        |
| Bit 2:1  | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                        |
| Bit 0    | RST       | 0x0         | wo   | Reset CRC calculation unit<br>It is set by software and cleared by hardware. To reset CRC calculation unit, the data register is set as 0xFFFF FFFF.<br>0: No effect<br>1: Reset                  |

### 10.3.4 Initialization register (CRC\_IDT)

| Bit      | Name | Reset value | Type | Description                                                                                                                                                                                         |
|----------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | IDT  | 0xFFFF FFFF | rw   | Initialization data value<br>When CRC reset is triggered by the RST bit in the CRC_CTRL register, the value in the initialization register is written into the CRC_DT register as an initial value. |

### 10.3.5 Polynomial register (CRC\_POLY)

| Bit      | Name | Reset value | Type | Description                                                                                                                                                                                                         |
|----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | POLY | 0x04C1 1DB7 | rw   | Polynomial coefficient<br>The generating polynomial is used as the division in CRC calculation. In CRC32 algorithm, the polynomial coefficient is set to 0x4C11DB7. The polynomial can also be programmed by users. |

# 11 I<sup>2</sup>C interface

## 11.1 I<sup>2</sup>C Introduction

I<sup>2</sup>C (inter-integrated circuit) bus interface manages the communication between the microcontroller and serial I<sup>2</sup>C bus. It supports master and slave modes, with up to 1 Mbit/s of communication speed (enhanced edition).

## 11.2 I<sup>2</sup>C main features

- I<sup>2</sup>C bus
  - Master and slave modes
  - Multimaster capability
  - Standard mode (100 KHz), fast mode (400 KHz) and enhanced fast mode (1 MHz)
  - 7-bit and 10-bit address modes
  - Two 7-bit slave addresses (2 addresses, one of them can be masked)
  - Broadcast call mode
  - Programmable data setup and hold time
  - Clock stretching capability
- Support DMA transfer
- Programmable digital noise filter
- Support SMBus 2.0 protocol
  - PEC generation and verification
  - Acknowledgement control for command and data
  - ARP ((address resolution protocol)
  - Master capability
  - Device capability
  - SMBus reminder capability
  - Timeout detection
  - Idle detection
- PMBus

## 11.3 I<sup>2</sup>C function overview

I<sup>2</sup>C bus consists of a data line (SDA) and clock line (SCL). It can achieve a maximum of 100 KHz speed in standard mode, up to 400 KHz in fast mode and 1MHz in fast plus mode. A frame of data transmission begins with a Start condition and ends with a Stop condition. The bus is kept in busy state after receiving the Start condition, and becomes idle as long as it receives the Stop condition.

Start condition: SDA switches from high to low when SCL is set high

Stop condition: SDA switches from low to high when SCL is set high

Figure 11-1 I<sup>2</sup>C bus protocol



## 11.4 I<sup>2</sup>C Interface

The figure below shows the block diagram of I<sup>2</sup>C interface.

Figure 11-2 I<sup>2</sup>C interface block diagram



### 1. Operating mode

I<sup>2</sup>C bus interface can operate both in master mode and slave mode. Switching from master mode to slave mode, vice versa, is supported as well. By default, the interface operates in slave mode. When the Start condition is activated, the I<sup>2</sup>C bus interface switches from slave mode to master mode, and returns to slave mode automatically at the end of data transfer (Stop condition is triggered).

### 2. Communication process

- Master mode communication:
  1. Start condition generation
  2. Address transmission
  3. Data Tx or Rx
  4. Stop condition generation
  5. End of communication
- Slave mode communication:
  1. Wait until the address is matched
  2. Data Tx or Rx
  3. Wait for the generation of Stop condition
  4. End of communication

### 3. Digital filter capability

The digital filter is available on both SCL and SDA lines. It is enabled by setting the DFLT[3:0] bit (0~15) in the I<sup>2</sup>C\_CTRL1 register to reduce noise on bus on a large scale. The filter time is DFLT x T<sub>I<sup>2</sup>C\_CLK</sub>. The digital filter is not allowed to be altered when the I<sup>2</sup>C is enabled.

### 4. Address control

Both master and slave support 7-bit and 10-bit addressing modes.

#### Slave address mode:

- In 7-bit mode (ADDR1MODE=0)
  - ADDR1EN=1, ADDR2EN=0 stands for a single address mode: only matches OADDR1
  - ADDR1EN=1, ADDR2EN=1 stands for dual address mode: matches OADDR1 and OADDR2
- In 10-bit mode (ADDR1MODE=1)
  - Only supports a single address mode (ADDR1EN=1, ADDR2EN=0), matches OADDR1

#### Slave address masking capability

The Slave address 2 (OADDR2) is maskable, which is done by setting the ADDR2MASK[2:0].

- 0: Address bit [7:1]
- 1: Address bit [7:2]
- 2: Address bit [7:3]

- 3: Address bit [7:4]
- 4: Address bit [7:5]
- 5: Address bit [7:6]
- 6: Address bit [7]
- 7: All addresses, excluding those reserved by I<sup>2</sup>C

**Support special slave address:**

- Broadcast call address (0b0000000x): This address is enabled when GCAEN=1
- SMBus device default address (0b1100001x): This address is enabled for SMBus address resolution protocol in SMBus device mode (DEVADDREN = 1)
- SMBus master default address (0b0001000x): This address is enabled for SMBus master notification protocol in SMBus master mode (HADDREN = 1)
- SMBus alert address (0b0001100x): This address is enabled for SMBus alert response address protocol in SMBus master mode when SMBALERT = 1

Refer to *SMBus2.0 protocol* for more information.

**Slave address matching procedure:**

- Receive a Start condition
- Address matching
- The slave sends an ACK if address is matched
- ADDRF=1, with SDIR indicating the transmission direction
  - When SDIR=0, slave enters receiver mode, starting receiving data.
  - When SDIR=1, slave enters transmitter mode, starting transmitting data.

**5. Clock stretching capability**

Clock stretching is enabled by default (STRETCH=0 in the I2C\_CTRL1 register). The slave can hold the SCL line low for software operation. If the clock stretching capability is not supported by master, then the STRETCH must be set to 1 in the I2C\_CTRL1 register.

It should be noted that the clock stretching capability of I<sup>2</sup>C slave must be configured before the I<sup>2</sup>C peripherals are enabled.

**Clock stretching capability enabled**

I<sup>2</sup>C slave stretches the SCL clock in one of the following conditions:

- Address reception: When the address received by slave matches the local address enabled (ADDRF=1 in the I2C\_STS), the SCL line is pulled down until the ADDRF is cleared by setting the ADDRC in the I2C\_CLR.
- Data reception: When the shift register has received another new byte before the data in the I2C\_RXDT register is read, the SCL line will be pulled low until the data in I2C\_RXDT register is read.
- Data transmission: If no data is written when the ADDRF is cleared, and TDRE= 1 in the I2C\_STS register, then the SCL line will be pulled low until data is written to the I2C\_TXDT.
- Data transmission: If no data is written to the I2C\_TXDT after the completion of the previous data transfer, the SCL line will be pulled low until data is written to the I2C\_TXDT.
- When slave byte control mode is selected (SCTRL=1 in the I2C\_CTRL1 register) and RLDEN=1 in the I2C\_CTRL2 register, if TCRLD = 1, indicating the completion of the last data transfer, then the TCRLD will be cleared by hardware so as to release the SCL line after a non-zero value is written to the CNT bit of I2C\_CTRL2 register.

**Clock stretching capability disabled**

The SCL clock is disabled when STRETCH=1 in the I2C\_CTRL1 register, with the following conditions worth notice:

- Address reception: The SCL clock is not stretched when the address received by slave matches the local address enabled (ADDRF=1 in the I2C\_STS),.
- Data reception: If no data is read from the I2C\_RXDT register before the next ACK signal, an overflow will occur, and the OUF bit in the I2C\_STS register will also be set to 1.
- Data transmission: If no data is written to the I2C\_TXDT register after the completion of the previous data transfer, an underflow will occur, and the OUF bit in the I2C\_STS register will also be set to 1.

### 11.4.1 I<sup>2</sup>C timing control

I<sup>2</sup>C core is clocked by I2C\_CLK, whereas the I2C\_CLK is clocked by PCLK1. The PCLK1 should be set to be less than 4/3 SCL cycles.

The corresponding bits in the I2C\_CLKCTRL register are used for timing configuration.

- DIV[7:0]: I<sup>2</sup>C clock divider
- SDAD[3:0]: data hold time ( $t_{HD;DAT}$ )
- SCLD[3:0]: Data setup time ( $t_{SU;DAT}$ )
- SCLH[7:0]: SCL high
- SCLL[7:0]: SCL low

Note: Timing configuration cannot be modified once the I<sup>2</sup>C is enabled.

Figure 11-3 Setup and hold time



It is possible to configure data hold time ( $t_{HD;DAT}$ ) and data setup time ( $t_{SU;DAT}$ ) freely by setting the DIV[7:0], SDAD[3:0] and SCLD[3:0] bits in the I2C\_CLKCTRL register.

- Data hold time ( $t_{HD;DAT}$ ): refers to the duration from SCL falling edge to SDA output

$$t_{HD;DAT} = T_{SDAD} + t_{SYNC}$$

$$T_{SDAD} = SDAD \times (DIV + 1) \times T_{I2C\_CLK}$$

$$t_{SYNC} = (DFLT + 3) \times T_{I2C\_CLK} - t_f$$

$t_{SYNC}$  consists of three parts:

- SCL falling edge time ( $t_f$ )
- Digital filter input latency (DFLT x T<sub>I2C\_CLK</sub>)
- Synchronization delay between SCL and I<sup>2</sup>C\_CLK (2~3 I<sup>2</sup>C\_CLK cycles)

- Data setup time ( $t_{SU;DAT}$ ): refers to the duration from SDA output to SCL rising edge

$$t_{SU;DAT} = SCLD \times (DIV+1) \times t_{I2C\_CLK} - t_f$$

In master mode, the width of SCL signals (high and low) can be configured freely by setting the DIV[7:0], SCLH[7:0] and SCLL[7:0] bits in the I2C\_CLKCTRL register.

SCL low: When the SCL low signal is detected, the internal SCLL counter starts counting until it reaches the SCLL value. At this point, the SCL line is released and become high.

SCL high: When the SCL high signal is detected, the internal SCLH counter starts counting. When the counter value reaches the SCLH value, the SCL line is pulled low. In the process of SCL remaining high, if it is pulled low by external bus, the internal SCLH counter will stop counting and start counting in SCL low mode, laying the foundation for clock synchronization.

- SCL high signal width:

$$t_{HIGH} = T_{SCLH} = (SCLH + 1) \times (DIV + 1) \times T_{I2C\_CLK}$$

- SCL low signal width:

$$T_{Low} = T_{SCLL} = (SCLL + 1) \times (DIV + 1) \times T_{I2C\_CLK}$$

Table 11-1 I<sup>2</sup>C timing specifications

| Parameter                |                      | Standard mode |      | Fast mode |      | Fast mode plus |      | SMBus |      |
|--------------------------|----------------------|---------------|------|-----------|------|----------------|------|-------|------|
|                          |                      | Min.          | Max. | Min.      | Max. | Min.           | Max. | Min.  | Max. |
| f <sub>SCL</sub> (kHz)   | SCL clock frequency  |               | 100  |           | 400  |                | 1000 |       | 100  |
| t <sub>Low</sub> (us)    | SCL clock low        | 4.7           |      | 1.3       |      | 0.5            |      | 4.7   |      |
| t <sub>HIGH</sub> (us)   | SCL clock high       | 4.0           |      | 0.6       |      | 0.26           |      | 4.0   | 50   |
| t <sub>HD;DAT</sub> (us) | Data hold time       | 0             |      | 0         | 0.9  | 0              | 0.45 | 300   |      |
| t <sub>SU;DAT</sub> (ns) | Data setup time      | 250           |      | 100       |      | 50             |      | 250   |      |
| t <sub>r</sub> (ns)      | SCL/SDA rising edge  |               | 1000 |           | 300  |                | 120  |       | 1000 |
| t <sub>f</sub> (ns)      | SCL/SDA falling edge |               | 300  |           | 300  |                | 120  |       | 300  |

## 11.4.2 Data transfer management

Data transfer counter is available in the I<sup>2</sup>C interface to control communication flow. It is mainly used for:

- NACK transmission: master reception mode
- STOP transmission: master reception/transmission modes
- RESTART generation: master reception/transmission modes
- ACK control: slave mode (SMBus)
- PEC transmission/reception: master/slave modes

Generally, the data transfer management counter (by setting the CNT[7:0] bit in the I2C\_CTRL2 register) is applicable to master mode, and it is disabled in slave mode. This counter is used only in SMBus mode for the ACK control and PEC reception of each byte by the slave. In SMBus mode, the slave enables data counter with the SCTRL bit in the I2C\_CTRL1 register.

### Byte control through master

The CNT[7:0] bit in the I2C\_CTRL2 register is used to configure the number of bytes to be transferred, ranging from 1 to 255. If the number of data to be transferred is greater than 255, then the RLDEN bit in the I2C\_CTRL2 register has to be set to 1 to enable reload mode. The following configuration processes are described in two aspects:

- ≤255 bytes, for example, the number of data to be transferred is 100 bytes
  - Step 1: Disable reload mode by setting RLDEN=0;
  - Step 2: Set CNT[7:0]=100.
- >255 bytes, for example, the number of data to be transferred is 600 bytes
  - Step 1: Enable reload mode by setting RLDEN=1;
  - Step 2: Set CNT[7:0]=255, then the remaining bytes are 600-255=345;
  - Step 3: After the completion of 255-byte data transfer, the TCRLD=1 in the I2C\_STS register, and then set CNT[7:0]=255 for continuous transfer, and the remaining bytes are 345-255=90;
  - Step 4: After the completion of the second 255-byte data transfer, the TCRLD=1 in the I2C\_STS register, and then set RLDEN=0 to disable reload mode before setting CNT[7:0]=90 for continuous transfer.

There are two ways to stop the last data transfer (RLDEN=0, reload mode disabled):

- Stop data transfer automatically (ASTOPEN=1 in the I2C\_CTRL2 register)
  - When the number of data programmed in the CNT[7:0] bit has been fully transferred, the master will automatically send a STOP condition.
- Stop data transfer by software (ASTOPEN=0 in the I2C\_CTRL2 register)
  - When the number of data programmed in the CNT[7:0] has been fully transferred, the TDC=1 in the I2C\_STS register, the SCL will be pulled low at this point, and an interrupt is generated if the TDCIEN is generated. In this case, it is possible to send a STOP condition by setting GENSTOP=1 in the I2C\_CTRL2 register, or send a RESTART condition by setting GENSTART=1 in the I2C\_CTRL2 register, before clearing TDC flag by software.

### Byte control through slave

This feature is enabled by setting the SCTRL bit in the I2C\_CTRL1 register so that the slave is able to control ACK/NACK of each byte independently.

- Proceed as below:
  - Set SCTRL=1 to enable Byte Control Through Slave;
  - After the slave address is matched (ADDRF=1), enable reload mode by setting RLDEn=1, and then set CNT[7:0]=1;
  - When a byte is received, the TCRLD=1 in the I2C\_STS register, and the slave will pull the SCL bus low between the 8th and 9th clock edges. At this point, the user can read the RXDT register and generate an ACK or NACK signal through the NACKEN bit in the I2C\_CTRL2 register.
  - When an NACK signal is generated, it indicates the end of communication.
  - When an ACK signal is generated, the communication flow keeps going on. At this point, set CNT[7:0]=1, the TCRLD flag is cleared automatically by hardware, and the SCL bus is released for the reception of the next byte.

As we know, the value in the CNT[7:0] bit is not limited to 1. If you want to receive 8 data, for example, but just want to control the ACK/NACK signals of the 8th data, proceed as below: set CNT[7:0]=8, the slave will receive 7 consecutive data, with ACK signals sent. Once the 8th data reception is completed, the SCL bus is pulled low, and then proceed as above to select whether to send an ACK or NACK

It should be noted that the clock stretching capability must be enabled (STRETCH=0 in the I2C\_CTRL1 register) before selecting Byte Control Mode Through Slave.

Table 11-2 I<sup>2</sup>C configuration

| Description                                   | RLDEN bit | ASTOPEN bit | SCTRL bit |
|-----------------------------------------------|-----------|-------------|-----------|
| Master transmit/receive RESTART               | 0         | 0           | ×         |
| Master transmit/receive STOP                  | 0         | 1           | ×         |
| Slave receive (ACK response to all bytes)     | 1         | ×           | 1         |
| Slave receive (control ACK/NACK of each byte) | X         | ×           | 0         |

### 11.4.3 I<sup>2</sup>C master communication flow

#### 1. I<sup>2</sup>C clock initialization ( by setting the I2C\_CLKCTRL register)

- I<sup>2</sup>C clock divider: DIV[7:0]
- Data hold time ( $t_{HD;DAT}$ ): SDAD[3:0]
- Data setup time ( $t_{SU;DAT}$ ): SCLD[3:0]
- SCL high duration: SCLH[7:0]
- SCL low duration: SCLL[7:0]

The register can be configured by means of Artery\_I2C\_Timing\_Configuration tool.

#### 2. Set the number of bytes to be transferred

- <255 bytes
  - Set RLDEn=0 in the I2C\_CTRL2 register to disable reload mode;
  - Set CNT[7:0]=N in the I2C\_CTRL2 register.
- >255 bytes
  - Set RLDEn=1 in the I2C\_CTRL2 register to enable reload mode;
  - Set CNT[7:0]=255 in the I2C\_CTRL2 register;
  - Remaining bytes N=N-255.

#### 3. End of data transfer

- ASTOPEN=0: stop data transfer by software. After the completion of data transfer, the TDC is set in the I2C\_STS register, and GENSTOP=1 or GENSTART=1 is written by software to send a STOP or START condition.
- ASTOPEN=1: data transfer is stopped automatically. A STOP condition is sent at the end of data transfer.

**4. Set slave address**

- Set slave address value (by setting the SADDR bit in the I2C\_CTRL2 register);
- Set slave address mode (by setting the ADDR10 bit in the I2C\_CTRL2 register):
  - ADDR10=0: 7-bit address mode
  - ADDR10=1: 10-bit address mode

**5. Set transfer direction (by setting the DIR bit in the I2C\_CTRL2 register)**

- DIR=0: Master reception
- DIR=1: Master transmission

**6. Start data transfer**

When GENSTART=1 in the I2C\_CTRL2 register, the master starts sending a START condition and slave address. After receiving the ACK from the slave, ADDRFL=1 is asserted in the I2C\_STS register. The ADDRFL flag can be cleared by setting ADDRC=1 in the I2C\_CLR register, and then data transfer starts.

**7. Master transmit**

1. I2C\_TXDT data register is empty, the shift register is empty, and TDIS=1 in I2C\_STS register;
2. Write data 1 to the TXDT register, and data is immediately moved to the shift register;
3. TXDT register becomes empty, and TDIS=1 again;
4. Write data 2 to the TXDT register, and TDIS is cleared;
5. Repeat step 2 and 3 until the data in the CNT[7:0] is sent;
6. If TCRLD=1 (reload mode) in the I2C\_STS register, the following two circumstances should be noted:

Remaining bytes  $N > 255$ : Writing 255 to the CNT bit,  $N=N-255$ , TCRLD is cleared, and data transfer continues;

Remaining bytes  $N \leq 255$ : Disable reload mode (RLDEN=0), write N to the CNT bit, TCRLD is cleared, and data transfer continues.

**8. Master receive**

1. After the slave address is matched, ADDRFL=1 in the I2C\_STS register, clear the ADDRFL flag by setting ADDRC=1 in the I2C\_CLR register, and then it starts sending data;
2. After the reception of data, RDBF=1; read the RXDT register will clear the RDBF automatically;
3. Repeat step 2 until the reception of data programmed in the CNT[7:0];
4. If TCRLD=1 (reload mode) in the I2C\_STS register, the following two circumstances should be noted:

Remaining bytes  $N > 255$ : Writing 255 to the CNT bit,  $N=N-255$ , TCRLD is cleared, and data transfer continues;

Remaining bytes  $N \leq 255$ : Disable reload mode (RLDEN=0), write N to the CNT bit, TCRLD is cleared, and data transfer continues.

5. After the reception of the last data, an NACK signal will be sent by master.

**9. Stop condition**

- STOP condition generation:
  - ASTOPEN=0: TDC=1 in the I2C\_STS register, set GENSTOP=1 to generate a STOP condition
  - ASTOPEN=1: A STOP condition is generated automatically
- Wait for the generation of a STOP condition. When a STOP condition is generated, STOPFL=1 is asserted in the I2C\_STS register. The STOPFL flag can be cleared by setting STOPC=1 in the I2C\_CLR register, and then transfer stops.

When the master receives an NACK signal during transmission, then ACKFAIL is set in the I2C\_STS register, and a STOP condition is sent to stop communication, whatever mode (either ASTOPEN=0 or ASTOPEN=1).

## Master transmitter

Figure 11-4 I<sup>2</sup>C master transmission flow



Figure 11-5 Transfer sequence of I<sup>2</sup>C master transmitter**Master receiver**Figure 11-6 I<sup>2</sup>C master receive flow

Figure 11-7 Transfer sequence of I<sup>2</sup>C master receiver**Master special transfer sequence**

In 10-bit addressing mode, the READH10 bit in the I<sup>2</sup>C\_CTRL2 register is used to generate a special timing. When READH10=1, the master sends data to the slave before read access to the slave, as shown in the figure below:

Operating method:

When ASTOPEN=0, data is transferred from the master to the slave. At the end of data transfer, READH10=0 is asserted, and then the master starts receiving data from the slave.

Figure 11-8 10-bit address read access when READH10=1



Figure 11-9 10-bit address read access when READH10=0



## 11.4.4 I<sup>2</sup>C slave communication flow

### 1. I<sup>2</sup>C clock initialization (I2C\_CLKCTRL register)

- **I<sup>2</sup>C clock division:** DIV[7: 0]
- **Data hold time ( $t_{HD;DAT}$ ):** SDAD[3: 0]
- **Data setup time ( $t_{SU;DAT}$ ):** SCLD[3: 0]

This register can be configured using Artery\_I2C\_Timing\_Configuration tool.

### 2. Set local address 1

- Set address mode:
  - 7-bit address: by setting ADDR1MODE=0 in the I2C\_OADDR1 register
  - 10-bit address: by setting ADDR1MODE=1 in the I2C\_OADDR1 register
- Set address 1: by setting the ADDR1 bit in the I2C\_OADDR1 register
- Enable address 1: by setting ADDR1EN=1 in the I2C\_OADDR1 register

### 3. Set local address 2

- Set address 2: by setting the ADDR2 bit in the I2C\_OADDR2 register
- Set address 2 mask bit: by setting the ADDR2MASK bit in the I2C\_OADDR2 register
- Enable address 2: by setting ADDR2EN=1 in the I2C\_OADDR2 register

Note: Only 7-bit address mode is available in the address 2 mode. The ADDR2MASK bit is used to mask some address bits freely so that the slave can respond to some specific addresses. Refer to Section 14.2 for more information about the ADDR2MASK bit.

In the case of using only one address, only address 1 needs to be configured, without the need of address 2 mode.

### 4. Wait for address matching

When the local address is received, the ADDRF bit is set in the I2C\_STS register. The data transfer direction can be obtained by read access to the SDIR bit in the I2C\_STS register. When SDIR=0, it indicates that the slave is receiving data, whereas SDIR=1 indicates that the slave is sending data. The ADDR[6:0] bit in the I2C\_STS register indicates what kind of address has been received, which is particularly helpful in the case when the dual address mode is used and the address 2 mode mask bit is set.

Data transfer starts when the ADDRF flag is cleared by setting ADDRC=1 in the I2C\_CLR register.

### 5. Data transfer (slave transmission, clock stretching enabled, STRETCH=0)

After address matching:

1. I2C\_TXDTdata register becomes empty, the shift register becomes empty, and TDIS=1 in the I2C\_STS register;
2. Write data 1 to the TXDT register, and data is immediately moved to the shift register;
3. TXDT register becomes empty, and TDIS=1 again;
4. Write data 2 to the TXDT register, and the TDIS is cleared;
5. Repeat steps 3 and 4 until the end of data transfer;
6. Wait for the generation of an NACK signal. Once received, the ACKFAILF is set in the I2C\_STS register. The ACKFAILF flag is cleared by setting ACKFAILC=1 in the I2C\_CLR register;
7. Wait for the generation of a STOP condition. Once received, the STOPF bit is set in the I2C\_STS register. The STOPF flag is cleared by setting STOPC=1 in the I2C\_CLR register, and transmission ends.

Note: In the case of the clock stretching being disabled (STRETCH=1), if data has not yet been written to the TXDT register before the transmission of the first bit of the to-be-transferred data (that is, before the generation of SDA edge), an underrun error may occur, and the OUF bit is set in the I2C\_STS register, sending 0xFF to the bus.

In order to write data in time, data must be written to the DT register first before communication, in two different ways:

- Write operation through software: Clear the TXDT register by setting TDBE=1 through software; then write the first data to the TXDT register, and the TDBE bit is cleared.
- Write operation through interrupts or DMA: Clear the TXDT register by setting TDBE=1 through software; then set TDIS=1 to generate a TDIS event, which generates an interrupt or

DMA request. At this point, data is written to the TXDT register using DMA or interrupt functions.

## 6. Data transfer (slave receive, clock stretching enabled, STRETCH=0)

After address matching:

1. I2C\_RXDTRegister becomes empty, the shift register becomes empty, and RDBF=0 in the I2C\_STS register;
2. After the reception of data, RDBF=1; read the RXDT register will clear the RDBF automatically;
3. Repeat step 2 until the completion of all data transfer;
4. Wait for the generation of a STOP condition. Once received, the STOPF bit in the I2C\_STS register is set. The STOPF flag is cleared by setting STOPC=1 in the I2C\_CLR register, and transmission ends.

In slave receive mode, the slave byte control mode (SCTRL=1) can be used for data reception. This mode allows to control ACK/NACK signals of each byte received. This mode is typically available in SMBus protocol. Refer to 11.4.2 Data transfer management for more information about this mode.

Note that the slave must read the received data in the case of the clock stretching being disabled (STRETCH=1). If one-byte data has been received and data is not read yet before the end of the next data reception, an overrun error occurs, setting the OUF bit in the I2C\_STS register and sending NACK.

An interrupt will be generated if the corresponding interrupt enable bit is enabled. For more information about interrupt generation, refer to the interrupt chapter.

### Slave transmitter

Figure 11-10 I<sup>2</sup>C slave transmission flow



Figure 11-11 I<sup>2</sup>C slave transmission timing**Slave receiver**Figure 11-12 I<sup>2</sup>C slave receive flow

Figure 11-13 I<sup>2</sup>C slave receive timing

## 11.4.5 SMBus

The System Management Bus (SMBus) is a two-wire interface through which various devices can communicate with each other. It is based on I<sup>2</sup>C. With SMBus, the device can provide manufacturer information, tell the system its model/part number, report different types of errors and accept control parameters and so on. For more information, refer to SMBus 2.0 protocol.

The SMBus specification defines three types of devices.

### Difference between SMBus and I<sup>2</sup>C

1. SMBus requires a minimum speed of 10 KHz for the purpose of management and monitor. It is quite easy to know whether the bus is in Idle state or not as long as a parameter is input while running on a certain transmission speed, without the need of detecting the STOP signals one after another, or even keeping STOP and other parameter monitor. There is no limit for I<sup>2</sup>C.
2. SMBus transmission speed ranges from 10 KHz to 100 KHz. In contrast, I<sup>2</sup>C has no minimum requirement, and its maximum speed varies from one mode to another, namely, 100 KHz in standard mode and 400 KHz in fast mode.
3. After reset, SMBus needs timeout, but there is no limit for I<sup>2</sup>C in this regard.

### SMBus address resolution protocol (ARP)

SMBus address conflicts can be resolved by dynamically assigning a new unique address to each device. Refer to SMBus 2.0 protocol for more information about ARP.

Setting the DEVADDREN bit in the I<sup>2</sup>C\_CTRL1 register can enable the I<sup>2</sup>C interface to recognize the default device address (0b1100001x). However, unique device identifier (UDID) and the detailed protocol implementation should be handled by software.

### SMBus host notify protocol

The slave device can send data to the master device through SMBus host notify protocol. For example, the slave can notify the host to implement ARP with this protocol. Refer to SMBus 2.0 protocol for details on SMBus host notify protocol.

In host mode (HADDREN =1), the I<sup>2</sup>C interface e is enabled to recognize the default host address (0b0001000x).

### SMBus Alert

SMBALERT is an optional signal that connects the ALERT pin between the host and the slave. With this signal, the slave notifies the host to access the slave. SMBALERT is a wired-AND signal. For more information about SMBus Alert, refer to SMBus2.0 protocol.

The detailed sequences are as follows:

#### SMBus host

1. Enable SMBus Alert mode by setting SMBALERT=1;
2. Enable ALERT interrupt if necessary;
3. When an alert event occurs on the ALERT pin (ALERT pin changes from high to low);
4. The host will generate ALERT interrupt if enabled;

5. The host then processes the interrupt and accesses to all devices through ARA (Alert Response Address 0001100x) so as to get the slave addresses. Only the devices with pulled-down SMBALERT can acknowledge ARA.
6. The host then continues to operate based on the slave addresses available.

#### SMBus slave

1. When an alert event occurs and the ALERT pin changes from high to low (SMBALERT=1), the slave responds to ARA (Alert Response Address, 0001100x);
2. Wait until the host gets the slave addresses through ARA;
3. Report its own address, but it continues to wait if the arbitration is lost;
4. Address is reported properly, and the ALERT pin is released (SMBALERT=0).

#### Packet error checking (PEC)

Packet error checking (PEC) is used to guarantee the correctness and integrity of data transfer. This is done by using CRC-8 polynomial:

$$C(x) = x^8 + x^2 + x + 1$$

PEC calculation is enabled when PECEN=1 in the I2C\_CTRL1 register to check address and data.

#### PEC transfer:

- Host: PEC transfer is enabled by setting PECTEN=1 in the I2C\_CTRL2 register. The host sends a PEC as soon as the number of data transfer reaches N-1 (CNT=N).
- Slave: PEC transfer is enabled by setting PECTEN=1 in the I2C\_CTRL2 register. When the number of data transfer reaches N-1 (CNT=N), the slave will consider the Nth data as a PEC and check it. A NACK will be sent if the PEC checking result is not correct, setting the PECERR flag in the I2C\_STS register. In case of slave transmission mode, a NACK must follow the PEC whatever the checking result.

#### SMBus timeout

The SMBus protocol specifies three timeout detection modes:

- Low level timeout ( $T_{TIMEOUT}$ ): The time duration when the SCL is kept low in a single mode (taking into account master/slave device, however actively or passively pulled low).
- Cumulative timeout for a slave device at low level ( $t_{LOW:SEXT}$ ): The cumulative time duration when the SCL is pulled low by a slave device during the period from a START condition to a STOP condition.
- Cumulative timeout for a master device at low level ( $t_{LOW:MEXT}$ ): The cumulative time duration when the SCL is pulled low by a master device during the period from the ACK of the last byte to the 8th bit of the next byte (a single byte).

It should be noted that both  $t_{LOW:SEXT}$  and  $t_{LOW:MEXT}$  only deal with the time when they set themselves low level, excluding the time when they are pulled low by external sources. In contrast, both of these cases are considered in the calculation of  $T_{TIMEOUT}$ .

Table 11-3 SMBus timeout specification

| Type of timeout | Min. | Max. | Unit |
|-----------------|------|------|------|
| $T_{TIMEOUT}$   | 25   | 35   | ms   |
| $t_{LOW:SEXT}$  | -    | 25   | ms   |
| $t_{LOW:MEXT}$  | -    | 10   | ms   |

The I<sup>2</sup>C peripherals embeds two counters for timeout detection, which can be configured through the I2C\_TIMEOUT register. When a timeout event occurs, the TMOUT is set in the I2C\_STS register. TMOUT bit can be cleared by writing 1 to the TMOUTC bit in the I2C\_CLR register.

- EXTTIME: This is used to the cumulative timeout detection for master/slave devices at low level.  
Timeout duration = (EXTTIME + 1) x 2048 x T<sub>I2C\_CLK</sub>
- TOTIME: This is used for clock level timeout detection, selected through the TOMODE bit.  
TOMODE=0: Low level timeout detection, timeout duration=(TOTIME + 1) x 2048 x T<sub>I2C\_CLK</sub>  
TOMODE=1: High level timeout detection, timeout duration=(TOTIME + 1) x 4 x T<sub>I2C\_CLK</sub>

Table 11-4 SMBus timeout detection configuration

| Type of timeout | Other configuration | Enable bit | Timeout calculation             |
|-----------------|---------------------|------------|---------------------------------|
| tTIMEOUT        | TOMODE=0            | TOEN=1     | (TOTIME + 1) x 2048 x TI2C_CLK  |
| tLOW:SEXT       | -                   | EXTEN=1    | (EXTTIME + 1) x 2048 x TI2C_CLK |
| tLOW:MEXT       | -                   | EXTEN=1    | (EXTTIME + 1) x 2048 x TI2C_CLK |

#### Slave receive byte control

In slave receive mode, the slave receive byte control mode (SCTRL=1) can be used to control ACK/NACK signals of each received byte. Refer to the 11.4.2 Data transfer management for more information.

Table 11-5 SMBus mode configuration

| Transfer mode                    | PECTEN | PECTEN | RLDEN | ASTOPEN | SCTRL |
|----------------------------------|--------|--------|-------|---------|-------|
| Master transmit/receive +STOP    | 1      | 1      | 0     | 1       | -     |
| Master transmit/receive +RESTART | 1      | 1      | 0     | 0       | -     |
| Slave receive                    | 1      | 1      | 1     | -       | 1     |
| Slave transmit                   | 1      | 1      | 0     | -       | -     |

#### How to use the interface in SMBus mode

- Set SMBus default address acknowledgement:

HADDREN=1: Master default address acknowledged (0b0001000x)

DEVADDREN=1: Device default address acknowledged (0b1100001x)

- Configure PEC

- Slave receive byte control mode can be enabled (with SCTRL bit in the I2C\_CTRL1) in slave mode, if necessary

- Other configurations follow the I<sup>2</sup>C

However, the detailed SMBus protocol implementation should be handled by software, since the I<sup>2</sup>C interface is only enabled to recognize the addresses of SMBus protocols.

### 11.4.6 SMBus master communication flow

The SMBus is similar to the I<sup>2</sup>C in terms of master communication flow.

- I<sup>2</sup>Cclock initialization (by setting the I2C\_CLKCTRL register)

- I<sup>2</sup>C clock divider: DIV[7:0]
- Data hold time (t<sub>HD;DAT</sub>): SDAD[3:0]
- Data setup time (t<sub>SU;DAT</sub>): SCLD[3:0]
- SCL high duration: SCLH[7:0]
- SCL low duration: SCLL[7:0]

The register can be configured by means of Artery\_I2C\_Timing\_Configuration tool.

- SMBus-related initialization

- Select SMBus host: host default address acknowledged (0b0001000x) by setting HADDREN=1
- Enable PEC calculation: set PECEN=1 in the I2C\_CTRL1 register
- Enable PEC transfer: set PECTEN=1 in the I2C\_CTRL2 register

- Set the number of bytes to be transferred

- Disable reload mode by setting RLDEN=0 in the I2C\_CTRL2 register
- Set CNT[7:0]=N in the I2C\_CTRL2 register

The number of bytes to be transferred is <255 in SMBus mode at one time.

- End of data transfer

- ASTOPEN=0: stop data transfer by software. After the completion of data transfer, the TDC is set in the I2C\_STS register, and GENSTOP=1 or GENSTART=1 s written by software to send

- a STOP or START condition.
  - ASTOPEN=1: data transfer is stopped automatically. A STOP condition is sent at the end of data transfer.
- 5. Set slave address**
- Set slave address value (by setting the SADDR bit in the I2C\_CTRL2 register)
  - Set 7-bit slave address mode (by setting ADDR10=0 in the I2C\_CTRL2 register)
- 6. Set transfer direction (by setting the DIR bit in the I2C\_CTRL2 register)**
- DIR=0: Master reception
  - DIR=1: Master transmission
- 7. Start data transfer**
- In case of GENSTART=1 in the I2C\_CTRL2 register, the master starts sending a START condition and slave address. After receiving the ACK from the slave, ADDR=1 is asserted in the I2C\_STS register. The ADDR flag can be cleared by setting ADDRC=1 in the I2C\_CLR register, and then data transfer starts.
- 8. Master transmit**
1. I2C\_TXDT data register is empty, the shift register is empty, and TDIS=1 in I2C\_STS register;
  2. Write data 1 to the TXDT register, and data is immediately moved to the shift register;
  3. TXDT register becomes empty, TDIS=1 again;
  4. Write data 2 to the TXDT register, and TDIS is cleared;
  5. Repeat steps 2 and 3 until the specified data (N-1) is sent;
  6. The master will automatically transmit the Nth data, that is, PEC.
- 9. Master receive**
1. After the reception of data, RDBF=1; read the RXDT register will clear the RDBF automatically;
  2. Repeat step 1 until the reception of the specified data (N). The Nth data is set as PEC. A NACK is automatically sent after the reception of the Nth data (PEC) whatever the PEC result.
- 10. STOP condition**
- STOP condition generation:
    - ASTOPEN=0: TDC=1 in the I2C\_STS register, set GENSTOP=1 to generate a STOP condition;
    - ASTOPEN=1: A STOP condition is generated automatically
  - Wait for the generation of a STOP condition. When a STOP condition is generated, STOPF=1 is asserted in the I2C\_STS register. The STOPF flag can be cleared by setting STOPC=1 in the I2C\_CLR register, and then transfer stops

Figure 11-14 SMBus master transmission flowchart



Figure 11-15 SMBus master transmission timing



## SMBus master reception procedure

Figure 11-16 SMBus master reception flowchart



Figure 11-17 SMBus master receive timing



### 11.4.7 SMBus slave communication flow

The SMBus is similar to the I<sup>2</sup>C in terms of slave communication flow.

#### 1. Set local address

- **I2C clock division:** DIV[7: 0]
- **Data hold time ( $t_{HD;DAT}$ ):** SDAD[3: 0]
- **Data setup time ( $t_{SU;DAT}$ ):** SCLD[3: 0]

This register can be configured using Artery\_I2C\_Timing\_Configuration tool.

#### 2. Set local address

- Set 7-bit address mode: by setting ADDR1MODE=0 in the I2C\_OADDR1 register
- Set address 1: by setting the ADDR1 bit in the I2C\_OADDR1 register
- Enable address 1: by setting ADDR1EN=1 in the I2C\_OADDR1 register

#### 3. SMBus-related initialization

- Select SMBus device: device default address acknowledged (0b1100001x) by setting DEVADDREN=1
- Enable PEC calculation: by setting PECEN=1 in the I2C\_CTRL1 register
- Set slave byte control mode:  
Slave transmit: disable byte control mode by setting SCTRL=0 in the I2C\_CTRL1 register  
Slave receive: enable byte control mode by setting SCTRL=1 in the I2C\_CTRL1 register

#### 4. Wait for address matching

When the local address is received, the ADDRF bit is set in the I2C\_STS register. The data transfer direction can be obtained by read access to the SDIR bit in the I2C\_STS register. When SDIR=0, it indicates that the slave is receiving data, whereas SDIR=1 indicates that the slave is sending data. The ADDR[6:0] bit in the I2C\_STS register indicates what kind of address has been received. Enable PEC transfer: by setting PECTEN=1 in the I2C\_CTRL2 register

Set the number of data to be transferred:

- Slave transmit: by setting CNT=N in the I2C\_CTRL2 register
- Slave receive: by setting CNT=1 in the I2C\_CTRL2 register

Set reload mode:

- Slave transmit: by setting RLDEN=0 in the I2C\_CTRL2 register
- Slave receive: by setting RLDEN=1 in the I2C\_CTRL2 register

The ADDRF flag can be cleared by setting ADDRC=1 in the I2C\_CLR register, and then data transfer starts.

#### 5. Data transfer (slave transmission, clock stretching enabled, STRETCH=0)

After address matching:

1. I2C\_TXDT data register becomes empty, the shift register becomes empty, and TDIS=1 in the I2C\_STS register;
2. Write data 1 to the TXDT register, and data is immediately moved to the shift register;
3. TXDT register is empty, and TDIS=1 again;
4. Write data 2 to the TXDT register, and TDIS is cleared;
5. Repeat steps 3 and 4 until data (N-1) is sent;
6. The slave will automatically transmit the Nth data, that is, PEC;
7. Wait for the generation of a NACK signal. Once received, the ACKFAILF is set in the I2C\_STS register. The ACKFAILF flag is cleared by writing 1 to the ACKFAILC bit;
8. Wait for the generation of a STOP condition. Once received, the STOPF is set in the I2C\_STS register. The STOPF is cleared by writing 1 to the STOPC bit in the I2C\_CLR register, and transmission ends.

#### 6. Data transfer (slave receive, clock stretching enabled, STRETCH=0)

After address matching:

1. I2C\_RXDT register becomes empty, the shift register becomes empty, and RDBF=0 in the I2C\_STS register;
2. Upon the receipt of one-byte data, RDBF=1 and TCRLD=1, then the SCL is pulled low by the slave;
3. Read the RXDT register, and the RDBF is cleared automatically;
4. The NACKEN bit in the I2C\_CTRL2 register can be configured to generate an ACK or NACK, if needed

If a NACK is detected, it indicates the completion of communication;

If an ACK is detected, communication continues. Writing CNT=1 will automatically clear the TCRLD flag by hardware, and the SCL is released by the slave for the reception of the next data.

5. Repeat steps 2/3/4 until the completion of data reception (N-1);
6. Set RLDEN=0 in the I2C\_CTRL2 register to disable reload mode. Set CNT=1 and repeat steps 2/3 to receive a PEC. The PECERR bit will be set if a PEC error occurs.
7. Wait for the generation of a STOP condition. Once received, the STOPF is set in the I2C\_STS register. The STOPF can be cleared by writing 1 to the STOPC bit in the I2C\_CLR register, and transfer ends.

**SMBus slave transmitter**

Figure 11-18 SMBus slave transmission flow



Figure 11-19 SMBus slave transmission timing



**SMBus slave receive**

Figure 11-20 SMBus slave receive flow



Figure 11-21 SMBus slave receive timing



### 11.4.8 Data transfer using DMA

I<sup>2</sup>C data transfer can be done using DMA controller so as to reduce the burden on the CPU. The TDEN and RDEN must be set 0 when using DMA for data transfer.

#### Transmission using DMA (DMATEN=1)

1. Set the peripheral address (DMA\_CxPADDR=I2C\_TXDT address);
2. Set the memory address (DMA\_CxMADDR=data memory address);
3. The transmission direction is set from memory to peripheral (DTD=1 in the DMA\_CHCTRL register);
4. Configure the total number of bytes to be transferred in the DMA\_CxDTCNT register;
5. Configure other parameters (such as priority, memory data width, peripheral data width, interrupts, etc.) in the DMA\_CHCTRL register;
6. Enable the DMA channel by setting CHEN=1 in the DMA\_CxCTRL register;
7. Enable I<sup>2</sup>C DMA request by setting DMATEN=1 in the I2C\_CTRL1 register. Once the TDIS bit in the I2C\_STS1 register is set, the data is loaded from the programmed memory to the I2C\_TXDT register through DMA;
8. When the number of data transfers, programmed in the DMA controller, is reached (DMA\_CxDTCNT), the data transfer is complete (An interrupt is generated if enabled);
9. Master transmitter: refer to the I<sup>2</sup>C master communication flow section for STOP condition.  
Slave transmitter: refer to the I<sup>2</sup>C slave communication flow section for STOP condition.

#### Reception using DMA (DMAREN=1)

1. Set the peripheral address (DMA\_CxPADDR= I2C\_RXDT address);
2. Set the memory address (DMA\_CxMADDR= data memory address);
3. The transmission direction is set from peripheral to memory (DTD=0 in the DMA\_CHCTRL register);
4. Configure the total number of bytes to be transferred in the DMA\_CxDTCNT register;
5. Configure other parameters (such as priority, memory data width, peripheral data width, interrupts, etc.) in the DMA\_CHCTRL register;
6. Enable the DMA channel by setting CHEN=1 in the DMA\_CxCTRL register;
7. Enable I<sup>2</sup>C DMA request by setting DMAREN=1 in the I2C\_CTRL1 register. Once the RDBF bit is set in the I2C\_STS1 register, the data is loaded from the I2C\_DT register to the programmed memory through DMA;
8. When the number of data transfers, programmed in the DMA controller, is reached (DMA\_TCNTx=0), the data transfer is complete (An interrupt is generated if enabled).
9. Master receiver: refer to the I<sup>2</sup>C master communication flow section for STOP condition.  
Slave receiver: refer to the I<sup>2</sup>C slave communication flow section for STOP condition.

## 11.4.9 Error management

The error management feature included in the I<sup>2</sup>C provides a guarantee for the reliability of communication. The manageable error events are listed below:

Table 11-6 I<sup>2</sup>C error events

| Error event      | Event flag | Enable control bit | Clear bit |
|------------------|------------|--------------------|-----------|
| SMBus Alert      | ALERTF     | ERRIEN             | ALERTC    |
| Timeout error    | TMOUT      | ERRIEN             | TMOUTC    |
| PEC error        | PECERR     | ERRIEN             | PECERRC   |
| Overrun/underrun | OUF        | ERRIEN             | OUFC      |
| Arbitration lost | ARLOST     | ERRIEN             | ARLOSTC   |
| Bus error        | BUSERR     | ERRIEN             | BUSERRC   |

### Overrun/Underrun (OUF)

In slave mode, an underrun/overrun may appear if the clock stretching feature is disabled (STRETCH=1 in the I<sup>2</sup>C\_CTRL1 register).

In slave transmit mode: if data has not yet been written to the TXDT register before the transmission of the first bit of the to-be-transferred data (that is, before the generation of SDA edge), an underrun error may occur, and the OUF bit is set in the I<sup>2</sup>C\_STS register, sending 0xFF to the bus.

In slave receive mode: The slave must read the received data as soon as it receives the data. If one-byte data has been received and data is not read yet before the end of the next data reception, an overrun error occurs, setting OUF=1 in the I<sup>2</sup>C\_STS register, and sending NACK.

### Arbitration lost (ARLOST)

An arbitration lost may occur when the device controls the SDA line to output high level but the actual bus output is low

- Master transmit: An arbitration may occur during an address transfer and a data transfer
- Master receive: An arbitration may occur during an address transfer and an ACK response
- Slave transmit: An arbitration may occur during a data transfer
- Slave receive: An arbitration may occur during an ACK response

Once an arbitration lost is detected, the ARLOST is set by hardware in the I<sup>2</sup>C\_STS register. The SCL and SDA buses will be released and go automatically back to slave mode.

### Bus error (BUSERR)

The SDA line, during a data transfer, must be kept in a stable state when the SCL is in high level. The SDA can be changed only when the SCL signal becomes low; otherwise, a bus error may appear.

- SDA changes from 1 to 0: a misplaced START condition
- SDA changes from 0 to 1: a misplaced STOP condition

Both of these conditions above may trigger a bus error. Once it occurs, the BUSERR is set by hardware in the I<sup>2</sup>C\_STS register.

### PEC error (PECERR)

The PEC is available only in SMBus mode. In master receive and slave receive modes, a PEC error may appear if the received PEC is not equal to the internally calculated PEC. In this case, the PECERR bit is set by hardware in the I<sup>2</sup>C\_STS register.

In slave receive mode, an NACK is sent when a PEC error is detected.

In master receive mode, an NACK is always sent, whatever the PEC check result.

### SMBus alert (ALERTF)

The SMBus alert feature is present when HADDREN=1 (SMBus master mode) and SMBALERT=1 (SMBus alert mode). Once an alert event is detected on the ALERT pin (ALERT pin changes from high to low), the ALERTF bit is set by hardware in the I<sup>2</sup>C\_STS register.

### Timeout error (TMOUT)

SMBus defines a timeout mechanism for the improvement of the system stability, preventing the bus from being pulled down in the case of a master or slave failure. Once a timeout event (defined in SMBus chapter) is detected, the TMOUT is set by hardware in the I2C\_STS register. If a timeout error occurs in slave mode, the SCL and SDA buses are immediately released; if a timeout error occurs in master mode, a STOP condition is automatically by host to abort the communication.

## 11.5 I<sup>2</sup>C interrupt requests

The following table lists all the I<sup>2</sup>C interrupt requests.

Table 11-7 I<sup>2</sup>C interrupt requests

| Interrupt event                          | Event flag | Enable control bit |
|------------------------------------------|------------|--------------------|
| Address matched                          | ADDRF      | ADDRIEN            |
| Acknowledge failure                      | ACKFAIL    | ACKFAILIEN         |
| Stop condition received                  | STOPF      | STOPIEN            |
| Transmit interrupt state                 | TDIS       | TDIEN              |
| Receive data buffer full                 | RDBF       | RDIEN              |
| Transfer complete, wait for loading data | TCRLD      | TDCIEN             |
| Data transfer complete                   | TDC        |                    |
| SMBus alert                              | ALERTF     |                    |
| Timeout error                            | TMOUT      |                    |
| PEC error                                | PECERR     | ERRIEN             |
| Overrun/underrun                         | OUF        |                    |
| Arbitration lost                         | ARLOST     |                    |
| Bus error                                | BUSERR     |                    |

## 11.6 I<sup>2</sup>C debug mode

When the microcontroller enters debug mode (Cortex®-M4F halted), the SMBUS timeout either continues to work or stops, depending on the I2Cx\_SMBUS\_TIMEOUT configuration bit in the DEBUG module.

## 11.7 I<sup>2</sup>C registers

These peripheral registers must be accessed by words (32 bits).

Table 11-8 I<sup>2</sup>C register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| I2C_CTRL1   | 0x00   | 0x00000000  |
| I2C_CTRL2   | 0x04   | 0x00000000  |
| I2C_OADDR1  | 0x08   | 0x00000000  |
| I2C_OADDR2  | 0x0C   | 0x00000000  |
| I2C_CLKCTRL | 0x10   | 0x00000000  |
| I2C_TIMEOUT | 0x14   | 0x00000000  |
| I2C_STS     | 0x18   | 0x00000000  |
| I2C_CLR     | 0x1C   | 0x00000000  |
| I2C_PEC     | 0x20   | 0x00000000  |

|          |      |            |
|----------|------|------------|
| I2C_RXDT | 0x24 | 0x00000000 |
| I2C_TXDT | 0x28 | 0x00000000 |

### 11.7.1 Control register 1 (I2C\_CTRL1)

| Bit       | Name       | Reset value | Type | Description                                                                                                                                                                                                                |
|-----------|------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | Reserved   | 0x00        | res  | Kept at its default value.                                                                                                                                                                                                 |
| Bit 23    | PECEN      | 0x0         | rw   | PEC calculation enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                        |
| Bit 22    | SMBALERT   | 0x0         | rw   | SMBus alert enable / pin set<br>To enable SMBus master alert feature:<br>0: SMBus alert disabled<br>1: SMBus alert enabled<br>To enable SMBus slave alert address:<br>0: Pin high<br>1: Pin low, response address 0001100x |
| Bit 21    | DEVADDREN  | 0x0         | rw   | SMBus device default address enable<br>0: Disabled<br>1: Enabled, response device default address 1100001x                                                                                                                 |
| Bit 20    | HADDREN    | 0x0         | rw   | SMBus host default address enable<br>0: Disabled<br>1: Enabled, response host address 0001000x                                                                                                                             |
| Bit 19    | GCAEN      | 0x0         | rw   | General call address enable<br>0: Disabled<br>1: Enabled, response address 0000000x                                                                                                                                        |
| Bit 18    | Reserved   | 0x0         | res  | Kept at its default value.                                                                                                                                                                                                 |
| Bit 17    | STRETCH    | 0x0         | rw   | Clock stretching mode<br>0: Enabled<br>1: Disabled<br>Note: this bit is valid only in slave mode<br>Note: this bit can be set only when I2C is disabled (I2CEN=0)                                                          |
| Bit 16    | SCTRL      | 0x0         | rw   | Slave receiving data control<br>0: Disabled<br>1: Enabled                                                                                                                                                                  |
| Bit 15    | DMAREN     | 0x0         | rw   | DMA receive data request enable<br>0: Disabled<br>1: Enabled                                                                                                                                                               |
| Bit 14    | DMATEN     | 0x0         | rw   | DMA transmit data request enable<br>0: Disabled<br>1: Enabled                                                                                                                                                              |
| Bit 13:12 | Reserved   | 0x0         | res  | Kept at its default value.                                                                                                                                                                                                 |
| Bit 11:8  | DFLT       | 0x0         | rw   | Digital filter value<br>The glitches less than the filter time on the SCL bus will be filtered; filter time = DFLT x T <sub>I2C_CLK</sub> .<br>Note: this bit can be set only when I2C is disabled (I2CEN=0)               |
| Bit 7     | ERRIEN     | 0x0         | rw   | Error interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                        |
| Bit 6     | TDCIEN     | 0x0         | rw   | Data transfer complete interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                       |
| Bit 5     | STOPIEN    | 0x0         | rw   | Stop generation complete interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                     |
| Bit 4     | ACKFAILIEN | 0x0         | rw   | Acknowledge fail interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                             |
| Bit 3     | ADDRIEN    | 0x0         | rw   | Address match interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                |
| Bit 2     | RDIEN      | 0x0         | rw   | Data receive interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                 |
| Bit 1     | TDIEN      | 0x0         | rw   | Data transmit data interrupt enable<br>0: Disabled                                                                                                                                                                         |

|       |       |     |    |                                                                               |
|-------|-------|-----|----|-------------------------------------------------------------------------------|
|       |       |     |    | 1: Enabled<br>I <sup>2</sup> C peripheral enable<br>0: Disabled<br>1: Enabled |
| Bit 0 | I2CEN | 0x0 | rw |                                                                               |

### 11.7.2 Control register 2 (I2C\_CTRL2)

| Bit       | Name       | Reset value | Type | Description                                                                                                                                                                                                                     |
|-----------|------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:27 | Reserved   | 0x00        | res  | Kept at its default value.                                                                                                                                                                                                      |
| Bit 26    | PECTEN     | 0x0         | rw   | Request PEC transmission enable<br>0: Transmission disabled<br>1: Transmission enabled<br>Note: this bit can be set only when I <sup>2</sup> C is enabled (I2CEN=1)                                                             |
| Bit 25    | ASTOPEN    | 0x0         | rw   | Automatically send stop condition enable<br>0: Disabled (Software sends STOP condition)<br>1: Enabled (Automatically send STOP condition)                                                                                       |
| Bit 24    | RLDEN      | 0x0         | rw   | Send data reload mode enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                       |
| Bit 23:16 | CNT[7:0]   | 0x00        | rw   | Transmit data counter<br>Note: This field is invalid in slave mode when SCTRL=0.<br>Note: this bit can be set only when I <sup>2</sup> C is disabled (I2CEN=0)                                                                  |
| Bit 15    | NACKEN     | 0x0         | rw   | Not acknowledge enable<br>0: Acknowledge enabled<br>1: Acknowledge disabled<br>Note: this bit can be set only when I <sup>2</sup> C is enabled (I2CEN=1)<br>Note: this bit is reset when I <sup>2</sup> C is disabled (I2CEN=0) |
| Bit 14    | GENSTOP    | 0x0         | rw   | Generate stop condition<br>0: No stop generation<br>1: Stop generation<br>Note: this bit can be set only when I <sup>2</sup> C is enabled (I2CEN=1)<br>Note: this bit is reset when a stop condition is detected.               |
| Bit 13    | GENSTART   | 0x0         | rw   | Generate start condition<br>0: No start generation<br>1: Start generation<br>Note: this bit can be set only when I <sup>2</sup> C is enabled (I2CEN=1)<br>Note: this bit is reset when a start condition is detected.           |
| Bit 12    | READH10    | 0x0         | rw   | 10-bit address header read enable<br>0: 10-bit address header read disabled<br>1: 10-bit address header read enabled                                                                                                            |
| Bit 11    | ADDR10     | 0x0         | rw   | Host sends 10-bit address mode enable<br>0: 7-bit address mode<br>1: 10-bit address mode                                                                                                                                        |
| Bit 10    | DIR        | 0x0         | rw   | Master data transmission direction<br>0: Transmit<br>1: Receive                                                                                                                                                                 |
| Bit 9:0   | SADDR[9:0] | 0x000       | rw   | Slave address sent by the master<br>In 7-bit address mode, BIT0 and BIT[9:8] don't care.                                                                                                                                        |

### 11.7.3 Address register 1 (I2C\_OADDR1)

| Bit       | Name       | Reset value | Type | Description                                                                                                                                 |
|-----------|------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved   | 0x0000      | res  | Kept at its default value.                                                                                                                  |
| Bit 15    | ADDR1EN    | 0x0         | rw   | Own Address 1 enable<br>0: Own Address 1 disabled<br>1: Own Address 1 enabled                                                               |
| Bit 14:11 | Reserved   | 0x0         | res  | Kept at its default value.                                                                                                                  |
| Bit 10    | ADDR1MODE  | 0x0         | rw   | Own Address 1 mode<br>0: 7-bit address<br>1: 10-bit address<br>Note: this bit can be set only when ADDR1EN is enabled (ADDR1EN=1)           |
| Bit 9:0   | ADDR1[9:0] | 0x000       | rw   | Own address 1<br>In 7-bit address mode, BIT0 and BIT[9:8] don't care.<br>Note: this bit can be set only when ADDR1EN is enabled (ADDR1EN=1) |

### 11.7.4 Address register 2 (I2C\_OADDR2)

| Bit       | Name           | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|----------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved       | 0x0000      | res  | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 15    | ADDR2EN        | 0x0         | rw   | Own address 2 enable<br>0: Own address 2 disabled<br>1: Own address 2 enabled                                                                                                                                                                                                                                                                                                               |
| Bit 14:11 | Reserved       | 0x0         | res  | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 10:8  | ADDR2MASK[2:0] | 0x0         | rw   | Own address 2-bit mask<br>000: Match Address bit [7:1]<br>001: Match Address bit [7:2]<br>010: Match Address bit [7:3]<br>011: Match Address bit [7:4]<br>100: Match Address bit [7:5]<br>101: Match Address bit [7:6]<br>110: Match Address bit [7]<br>111: Response all addresses other than those reserved for I2C<br>Note: this bit can be set only when ADDR2EN is enabled (ADDR2EN=1) |
| Bit 7:1   | ADDR2[7:1]     | 0x00        | rw   | Own address 2<br>7-bit address mode<br>Note: this bit can be set only when ADDR2EN is enabled (ADDR2EN=1)                                                                                                                                                                                                                                                                                   |
| Bit 0     | Reserved       | 0x0         | res  | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                  |

### 11.7.5 Timing register (I2C\_CLKCTRL)

| Bit       | Name      | Reset value | Type | Description                                                                      |
|-----------|-----------|-------------|------|----------------------------------------------------------------------------------|
| Bit 31:28 | DIVL[3:0] | 0x0         | rw   | Low 4 bits of clock divider value                                                |
| Bit 27:24 | DIVH[7:4] | 0x0         | rw   | High 4 bits of clock divider value<br>$DIV = (DIVH \ll 4) + DIVL$                |
| Bit 23:20 | SCLD[3:0] | 0x0         | rw   | SCL output delay<br>$T_{SCLD} = (SCLD + 1) \times (DIV + 1) \times T_{I2C\_CLK}$ |
| Bit 19:16 | SDAD[3:0] | 0x0         | rw   | SDA output delay<br>$T_{SDAD} = (SDAD + 1) \times (DIV + 1) \times T_{I2C\_CLK}$ |
| Bit 15:8  | SCLH[7:0] | 0x00        | rw   | SCL high level<br>$T_{SCLH} = (SCLH + 1) \times (DIV + 1) \times T_{I2C\_CLK}$   |
| Bit 7:0   | SCLL[7:0] | 0x00        | rw   | SCL low level<br>$T_{SCLL} = (SCLL + 1) \times (DIV + 1) \times T_{I2C\_CLK}$    |

Note: the clock control register (I2C\_CLKCTRL) can be set only if I2C is disabled (I2CEN=0).

## 11.7.6 Timeout register (I2C\_TIMEOUT)

| Bit       | Name          | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                        |
|-----------|---------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31    | EXTEN         | 0x0         | rw   | Cumulative clock low extend timeout enable<br>0: Disabled<br>1: Enabled<br>Corresponds to $T_{LOW:SEXT}$ / $T_{LOW:MEXT}$ in SMBus                                                                                                                                                                                                 |
| Bit 30:28 | Reserved      | 0x0         | res  | Kept at its default value.                                                                                                                                                                                                                                                                                                         |
| Bit 27:16 | EXTTIME[11:0] | 0x000       | rw   | Cumulative clock low extend timeout value<br>Timeout duration = $(EXTTIME + 1) \times 2048 \times T_{I2C\_CLK}$<br>Note: this bit can be set only when EXTEN is enabled (EXTEN=1)                                                                                                                                                  |
| Bit 15    | TOEN          | 0x0         | rw   | Detect clock low/high timeout enable<br>0: Disabled<br>1: Enabled<br>Corresponds to $T_{TIMEOUT}$ in SMBus                                                                                                                                                                                                                         |
| Bit 14:13 | Reserved      | 0x0         | res  | Kept at its default value.                                                                                                                                                                                                                                                                                                         |
| Bit 12    | TOMODE        | 0x0         | rw   | Clock timeout detection mode<br>0: Clock low level detection<br>1: Clock high level detection<br>Note: this bit can be set only when TOEN is enabled (TOEN=1)                                                                                                                                                                      |
| Bit 11:0  | TOTIME[11:0]  | 0x000       | rw   | Clock timeout detection time<br>For clock low level detection (TOMODE = 0):<br>Timeout duration = $(TOTIME + 1) \times 2048 \times T_{I2C\_CLK}$<br>For clock high level detection (TOMODE = 1):<br>Timeout duration = $(TOTIME + 1) \times 4 \times T_{I2C\_CLK}$<br>Note: this bit can be set only when TOEN is enabled (TOEN=1) |

## 11.7.7 Status register (I2C\_STS)

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                                 |
|-----------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24 | Reserved  | 0x00        | res  | Kept at its default value.                                                                                                                                                                  |
| Bit 23:17 | ADDR[6:0] | 0x00        | r    | Slave address matching value<br>In 7-bit address mode: Slave address received<br>In 10-bit address mode: 10-bit slave address header received                                               |
| Bit 16    | SDIR      | 0x0         | r    | Slave data transmit direction<br>0: Receive data<br>1: Transmit data                                                                                                                        |
| Bit 15    | BUSYF     | 0x0         | r    | Bus busy flag transmission mode<br>0: Bus idle<br>1: Bus busy<br>Once a START condition is detected, this bit is set. Once a STOP condition is detected, this bit is automatically cleared. |
| Bit 14    | Reserved  | 0x00        | res  | Kept at its default value.                                                                                                                                                                  |
| Bit 13    | ALERTF    | 0x0         | r    | SMBus alert flag<br>SMBus host: This bit indicates the reception of an alert signal (ALERT pin changes from high to low)<br>0: No alert signal received<br>1: Alert signal received         |
| Bit 12    | TMOUT     | 0x0         | r    | SMBus timeout flag<br>0: No timeout<br>1: Timeout                                                                                                                                           |
| Bit 11    | PECERR    | 0x0         | r    | PEC receive error flag<br>0: No PEC error<br>1: PEC error                                                                                                                                   |
| Bit 10    | OUF       | 0x0         | r    | Overflow or underflow flag<br>In transmission mode:<br>0: No overflow or underflow<br>1: Underrun<br>In reception mode:<br>0: No overflow or underflow<br>1: Overrun                        |
| Bit 9     | ARLOST    | 0x0         | r    | Arbitration lost flag<br>0: No arbitration lost detected                                                                                                                                    |

|       |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 1: Arbitration lost detected                                                                                                                                                                                                                                                                                                                                                                |
| Bit 8 | BUSERR   | 0x0 | r    | Bus error flag<br>0: No bus error occurred<br>1: Bus error occurred                                                                                                                                                                                                                                                                                                                         |
| Bit 7 | TCRLD    | 0x0 | r    | Transmission is complete, waiting to load data<br>0: Data transfer is not complete yet<br>1: Data transfer is complete<br><br>This bit is set when data transfer is complete (CNT = 1) and reload mode is enabled (RLDEN=1). It is automatically cleared when writing a CNT value.<br>This bit is applicable in master mode or when SCTRL=1 in slave mode.                                  |
| Bit 6 | TDC      | 0x0 | r    | Data transfer complete flag<br>0: Data transfer is not completed yet (the shift register still holds data)<br>1: Data transfer is completed (shift register become empty and data are completely sent to bus)<br><br>This bit is set when ASTOPEN = 0, RLDEN = 0 and CNT = 0.<br>It is automatically cleared after a START or a STOP condition is received.                                 |
| Bit 5 | STOPF    | 0x0 | r    | Stop condition generation complete flag<br>0: No Stop condition detected.<br>1: Stop condition detected.                                                                                                                                                                                                                                                                                    |
| Bit 4 | ACKFAILF | 0x0 | r    | Acknowledge failure flag<br>0: No acknowledge failure<br>1: Acknowledge failure                                                                                                                                                                                                                                                                                                             |
| Bit 3 | ADDRF    | 0x0 | r    | 0~7 bit address match flag<br>0: 0~7 bit address mismatch<br>1: 0~7 bit address match                                                                                                                                                                                                                                                                                                       |
| Bit 2 | RDBF     | 0x0 | r    | Receive data buffer full flag<br>0: Data register has not received data yet<br>1: Data register has received data                                                                                                                                                                                                                                                                           |
| Bit 1 | TDIS     | 0x0 | rw1s | Transmit data interrupt status<br>0: Data has been written to the I2C_TXDT<br>1: Data has been sent from the I2C_TXDT to the shift register. I2C_TXDT become empty, and thus the to-be transferred data must be written to the I2C_TXDT.<br>When the clock stretching mode is disabled, a TDIS event is generated by writing 1 so that data is written to the I2C_TXDT register in advance. |
| Bit 0 | TDBE     | 0x0 | rw1s | Transmit data buffer empty flag<br>0: I2C_TXDT holds data<br>1: I2C_TXDT is empty<br><br>This bit is only used to indicate the current status of the I2C_TXDT register. The I2C_TXDT register can be refreshed by writing 1 through software.                                                                                                                                               |

### 11.7.8 Status clear flag (I2C\_CLR)

| Bit       | Name     | Reset value | Type | Description                                                                                                           |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------|
| Bit 31:14 | Reserved | 0x00000     | res  | Kept at its default value.                                                                                            |
| Bit 13    | ALERTC   | 0x0         | w    | Clear SMBus alert flag<br>SMBus alert flag is cleared by writing 1.                                                   |
| Bit 12    | TMOUTC   | 0x0         | w    | Clear SMBus timeout flag<br>SMBus timeout flag is cleared by writing 1.                                               |
| Bit 11    | PECERRC  | 0x0         | w    | Clear PEC receive error flag<br>PEC receive error flag is cleared by writing 1.                                       |
| Bit 10    | OUFC     | 0x0         | w    | Clear overload / underload flag<br>The overload / underload flag is cleared by writing 1.                             |
| Bit 9     | ARLOSTC  | 0x0         | w    | Clear arbitration lost flag<br>The arbitration lost flag is cleared by writing 1.                                     |
| Bit 8     | BUSERRC  | 0x0         | w    | Clear bus error flag<br>The bus error flag is cleared by writing 1.                                                   |
| Bit 7:6   | Reserved | 0x0         | res  | Kept at its default value.                                                                                            |
| Bit 5     | STOPC    | 0x0         | w    | Clear stop condition generation complete flag<br>The stop condition generation complete flag is cleared by writing 1. |
| Bit 4     | ACKFAILC | 0x0         | w    | Clear acknowledge failure flag<br>The acknowledge failure flag is cleared by writing 1.                               |
| Bit 3     | ADDRC    | 0x0         | w    | Clear 0~7 bit address match flag<br>The 0~7 bit address match flag is cleared by writing 1.                           |
| Bit 2:0   | Reserved | 0x0         | res  | Kept at its default value.                                                                                            |

### 11.7.9 PEC register (I2C\_PEC)

| Bit      | Name        | Reset value | Type | Description                |
|----------|-------------|-------------|------|----------------------------|
| Bit 31:8 | Reserved    | 0x0000000   | res  | Kept at its default value. |
| Bit 7:0  | PECVAL[7:0] | 0x00        | r    | PEC value                  |

Note: The PEC register is reset when I2C is disabled (I2CEN=0)

### 11.7.10 Receive data register (I2C\_RXDT)

| Bit      | Name     | Reset value | Type | Description                |
|----------|----------|-------------|------|----------------------------|
| Bit 31:8 | Reserved | 0x0000000   | res  | Kept at its default value. |
| Bit 7:0  | DT[7:0]  | 0x00        | r    | Receive data register      |

Note: The receive register (I2C\_RXDT) is reset when I2C is disabled (I2CEN=0)

### 11.7.11 Transmit data register (I2C\_TXDT)

| Bit      | Name     | Reset value | Type | Description                |
|----------|----------|-------------|------|----------------------------|
| Bit 31:8 | Reserved | 0x0000000   | res  | Kept at its default value. |
| Bit 7:0  | DT[7:0]  | 0x00        | rw   | Transmit data register     |

# 12 Universal synchronous/asynchronous receiver/transmitter (USART)

## 12.1 USART introduction

The universal synchronous/asynchronous receiver/transmitter (USART) serves an interface for communication by means of various configurations and peripherals with different data formats. It supports asynchronous full-duplex and half-duplex as well as synchronous transfer. USART offers a programmable baud rate generator, which enables users to configure the required communication frequency by setting the system frequency and frequency divider.

In addition to standard NRZ asynchronous and synchronous receiver/transmitter communication protocols, USART also supports widely-used serial communication protocols such as LIN (Local Interconnection Network), IrDA (Infrared Data Association) SIRENDEC specification, Asynchronous SmartCard protocol defined in ISO7816-3 standard, CTS/RTS (Clear To Send/Request To Send) hardware flow operation, RS485 and Modbus.

It also allows multi-processor communication, and supports silent mode waken up by idle frames or ID matching to build up a USART network. Meanwhile, high-speed communication is possible by using DMA.

Figure 12-1 USART block diagram



### USART main features:

- Programmable full-duplex or half-duplex communication
  - Full-duplex, asynchronous communication
  - Half-duplex, single-wire communication
- Programmable communication modes
  - NRZ standard format (Mark/Space)

- LIN (Local Interconnection Network)
- IrDA SIR (SIR Serial Infrared)
- Asynchronous SmartCard protocol defined in ISO7816-3 standard: support 0.5 or 1.5 stop bits in Smartcard mode
- RS-232 CTS/RTS(Clear To Send/Request To Send) hardware flow operation
- Multi-processor communication with silent mode (waken up by configuring ID match and bus idle frame)
- Synchronous mode
- Programmable baud rate generator
  - Shared by transmission and reception
- Programmable frame format
  - Programmable data word length (7 bits, 8 bits or 9 bits)
  - Programmable stop bits: support 1 or 2 stop bits
  - Programmable parity control: transmitter with parity bit transmission capability, and receiver with received data parity check capability
  - Programmable data transmission order (MSB/LSB)
  - Programmable Tx/Rx pi polarity
  - Programmable DT polarity
- Programmable DMA multi-processor communication
- Programmable separate enable bits for transmitter and receiver
- Programmable output CLK phase, polarity and frequency
- Detection flags
  - Receive buffer full
  - Transmit buffer empty
  - Transfer complete flag
- Four error detection flags
  - Overrun error
  - Noise error
  - Framing error
  - Parity error
- Programmable 12 interrupt sources with flags
  - CTS level change
  - LIN break detection
  - Transmit data register empty
  - Transmission complete
  - Receive data register full
  - Idle bus detected
  - Overrun error
  - Framing error
  - Noise error
  - Parity error
  - Receiver timeout detection
  - Byte match detection

## 12.2 Full-duplex/half-duplex selector

The full-duplex and half-duplex selector enables USART to perform data exchanges with peripherals in full-duplex or half-duplex mode, which is achieved by setting the corresponding registers.

In two-wire unidirectional full-duplex mode (by default), TX pin is used for data output, while the RX pin is used for data input. Since the transmitter and receiver are independent of each other, USART is allowed to send/receive data at the same time so as to achieve full-duplex communication.

When the SLBEN is set to 1, the single-wire bidirectional half-duplex mode is selected for communication. In this case, the LINEN, CLKEN, SCMEN and IRDAEN bits must be set to 0. RX pin is inactive, while TX and SW\_RX are interconnected inside the USART. For the USART part, TX pins is used for data output, and SW\_RX for data input. For the peripheral part, bidirectional data transfer is executed through IO mapped by TX pin.

## 12.3 Mode selector

### 12.3.1 Introduction

USART mode selector allows USART to work in different operation modes through software configuration so as to enable data exchanges between USART and peripherals with different communication protocols.

USART supports NRZ standard format (Mark/Space), by default. It also supports LIN (Local Interconnection Network), IrDA SIR (Serial Infrared), Asynchronous Smartcard protocol in ISO7816-3 standard, RS-232 CTS/RTS (Clear To Send/Request To Send) hardware flow operation, silent mode and synchronous mode, depending on USART mode selection configuration.

### 12.3.2 Configuration procedure

Selection of operation mode is done by following the configuration process listed below. In addition, such configuration method, along with those of receiver and transmitter described in the subsequent sections, are used to make USART initialization configuration.

#### 1. LIN mode

Set LINEN=1, CLKEN=0, STOPBN[1:0]=00, SCMEN=0, SLBEN=0, IRDAEN=0, DBN[1:0]=00.

LIN master has break generation capability, and can transmit 13-bit low-level LIN synchronous break frame by setting SBF=1. The LIN slave has break detection capability, and can select 11-bit or 10-bit break detection by setting BFBN=1 or BFBN=0.

Figure 12-2 BFF and FERR detection in LIN mode



## 2. Smartcard mode

Set SCLEN=1, LINEN=0, SLBEN=0, IRDAEN=0, CLKEN=1, DBN[1:0]=01, PEN=1 and STOPBN[1:0]=11.

The polarity, phase and pulse number of the clock can be configured by setting the CLKPOL, CLKPHA and LBCP bits (Refer to Synchronous mode for details).

The assertion of the TDC flag can be delayed by setting the SCGT[7:0] bit (guard time bit). The TDF bit can be asserted high after the guard time counter reaches the value programmed in the SCGT[7:0] bit.

The Smartcard is a single-wire half-duplex communication protocol. The SCNACKEN bit is used to select whether to send NACK when a parity error occurs. This is to indicate to the Smartcard that the data has not been correctly received.

*Note: It is recommended to use 1.5 stop bits for both transmitting and receiving. The guard time for smart card must meet 1.5-bit time to receive back-to-back data.*

Figure 12-3 Smartcard frame format



## 3. Infrared mode

Set IRDAEN=1, CLKEN=0, STOPBN[1:0]=00, SCLEN=0 and SLBEN=0.

The infrared low-power mode can be enabled by setting IRDALP=1. In normal mode, the transmitted pulse width is specified as 3/16 bits. In infrared low-power mode, the pulse width is configurable, and the ISDIV[7:0] bit can be used to achieve the desired low-power frequency.

Figure 12-4 IrDA DATA(3/16) – normal mode



## 4. Modbus

USART only supports basic hardware required by Modbus/RTU and Modbus/ASCII implementation, which means that the control must be done by software and USART provides EOB (end of block) detection only.

In Modbus/RTU, the EOB detection is implemented by the programmable timeout recognizing the receive line idle time being larger than 2 bytes. Users can configure the RTOV register to set the required timeout value (unit: 1-bit width), and enable timeout detection by setting RTODEN=1. When the receive line idle time detected by USART receiver is equal to the programmed timeout value, the USART will set RTODF. An interrupt is generated when RTODIE=1, and the RTODF bit can be cleared by writing 1 to the RTODCF bit.

In Modbus/ASCII, the EOB detection is implemented by the byte match feature recognizing the special byte sequence (CR/LF). Write LF ASCII code to the ID[7:0] to enable byte match feature, by default. When the data received by USART matches ID[7:0], the USART will set CMDF. An interrupt is generated when CMDIE=1, and the CMDF bit can be cleared by writing 1 to the CMDCF bit.

## 5. Hardware flow control mode

Setting RTSEN=1 and CTSEN=1 will enable RTS and CTS flow control, respectively.

**RTS flow control:** When the USART receiver is ready to receive new data, the RTS becomes effective (pull down low). When the data is received in the receiver (at the beginning of each stop bit), the RTS bit is set, indicating that the data transmission is to be stopped at the end of the current frame.

**CTS flow control:** USART transmitter checks CTS input before transmitting the next frame. If CTS is effective (that is, CTS is low), the next data is to be transmitted. If CTS becomes invalid (CTS is high) during transmission, the data transmission will stop after the completion of the current transmission.

Figure 12-5 Hardware flow control



## 6. RS485 mode

This mode is enabled by setting RS485EN=1. The enable signal is output on the RTS pin. The DEP bit is used to select polarity of the DE signal. The TSDE[4:0] bit is used to define the latency before the transmission of the start bit on the transmitter side, and the TCDT[4:0] bit is used to define the latency before the TC flag is set following the stop bit at the end of the last data.

## 7. Silent mode

This mode is enabled by setting RM=1. When the WUM bit is set to 1 or 0, it wakes up from silent mode through ID match or idle bus, respectively. The ID[7:0] is configurable. The ID[7:0] or ID[3:0] can be selected by setting the IDBN bit. When ID match is selected, if the MSB of data bit is set, it indicates that the current data stands for ID.

When the parity check is disabled, if DBN[1:0]=10, MSB is USART\_DT[6]; if DBN[1:0]=00, MSB is USART\_DT[7]; if DBN[1:0]=01, MSB is USART\_DT[8].

When the parity check is enabled, if DBN[1:0]=10, MSB is USART\_DT[5]; if DBN[1:0]=00, MSB is USART\_DT[6]; if DBN[1:0]=01, MSB is USART\_DT[7].

When ID[3:0] is selected, the four LSB bits indicate the ID value. When ID[7:0] is selected, all LSB bits indicate the ID value except for the parity check bit and MSB bit.

Figure 12-6 Mute mode using Idle line or Address mark detection



## 8. Synchronous mode

Setting CLKEN=1 enables the synchronous mode and clock pin output. Select CK pin high or low in idle mode by setting the CLKPOL bit (1 or 0), and select to sample data on the second or first edge of the clock by setting the CLKPHA bit (1 or 0). The LBCP bit (1 or 0) is used to select whether to output clock on the last data bit, and the ISDIV[4:0] bit is used to select the required clock output frequency.

Figure 12-7 8-bit format USART synchronous mode



## 12.4 USART frame format and configuration

USART data frame consists of start bit, data bit and stop bit, with the last data bit being as a parity bit.

USART idle frame size is equal to that of the data frame under current configuration, but all bits are 1.

USART break frame size is the current data frame size plus its stop bit. All bits before the stop bit are 0. In non-LIN mode, a break frame transmission and detection must be in line with this rule. For instance, if DBN[1:0]=00, the break frame size for transmission and detection should be 10-bit low level plus its stop bit. In LIN mode, refer to Mode selector and configuration process for more details.

The DBN1 and DBN0 bits are used to program 7-bit (DBN[1:0]=10), 8-bit (DBN[1:0]=00) or 9-bit (DBN[1:0]=01) data bits.

Figure 12-8 Word length configuration



The STOPBN bit is used to program 1-bit (STOPBN=00), 0.5-bit (STOPBN=01), 2-bit (STOPBN=10) and 1.5-bit (STOPBN=11) stop bits.

Setting PEN=1 will enable the parity control. PSEL=1 indicates odd parity, while PSEL=0 for even parity. Once the parity control bit is enabled, the MSB of the data bit will be replaced with parity bit, that is, the significant bits is reduced by one bit.

Figure 12-9 Stop bit configuration



Set the MTF bit to determine whether MSB (MTF=1) first or LSB (MTF=0) first.

Set USART\_DT as 1=L,0=H (DTREV=1) or 0=L,1=H (DTREV=0) for transmission and reception by setting the DTREV bit.

Set the TXREV bit to select VDD=0/mark,Gnd=1/idle (TXREV=1) or VDD=1/idle,Gnd=0/mark (TXREV=0) for signal transmission on USART\_TX pin.

Set the RXREV bit to select VDD=0/mark,Gnd=1/idle (RXREV=1) or VDD=1/idle,Gnd=0/mark (RXREV=0) for signal transmission on USART\_RX pin.

## 12.5 DMA transfer introduction

Enable transmit data buffer and receive data buffer using DMA to achieve continuous high-speed transmission for USART, which is detailed in subsequent sections. For more information on specific DMA configuration, refer to DMA chapter.

### 12.5.1 Transmission using DMA

1. Select a DMA channel: Select a DMA channel from DMA channel map table described in DMA chapter.
2. Configure the destination of DMA transfer: Configure the USART\_DT register address as the destination address bit of DMA transfer in the DMA control register. Data will be sent to this address after transmit request is received by DMA.
3. Configure the source of DMA transfer: Configure the memory address as the source of DMA transfer in the DMA control register. Data will be loaded into the USART\_DT register from the memory address after transmit request is received by DMA.
4. Configure the total number of bytes to be transferred in the DMA control register.
5. Configure the channel priority of DMA transfer in the DMA control register.
6. Configure the DMA interrupt generation after half or full transfer in the DMA control register.
7. Enable DMA transfer channel in the DMA control register.

## 12.5.2 Reception using DMA

1. Select a DMA transfer channel: Select a DMA channel from DMA channel map table described in DMA chapter.
2. Configure the destination of DMA transfer: Configure the memory address as the destination of DMA transfer in the DMA control register. Data will be loaded from the USART\_DT register to the programmed destination after reception request is received by DMA.
3. Configure the source of DMA transfer: Configure the USART\_DT register address as the source of DMA transfer in the DMA control register. Data will be loaded from the USART\_DT register to the programmed destination after reception request is received by DMA.
4. Configure the total number of bytes to be transferred in the DMA control register.
5. Configure the channel priority of DMA transfer in the DMA control register.
6. Configure DMA interrupt generation after half or full transfer in the DMA control register.
7. Enable a DMA transfer channel in the DMA control register.

## 12.6 Baud rate generation

### 12.6.1 Introduction

USART baud rate generator uses an internal counter based on PCLK. The DIV (USART\_BAUDR[15:0] register) represents the overflow value of the counter. Each time the counter is full, it denotes one-bit data. Thus each data bit width refers to PCLK cycles x DIV.

The receiver and transmitter of USART share the same baud rate generator, and the receiver splits each data bit into 16 equal parts to achieve oversampling, so the data bit width should not be less than 16 PCLK periods, that is, the DIV value must be greater than or equal to 16.

### 12.6.2 Configuration

User can program the desired baud rate by setting different system clocks and writing different values into the USART\_BAUDR register. The calculation format is as follows:

$$\frac{\text{TX}}{\text{RX}} \text{ baud rate} = \frac{f_{CK}}{\text{DIV}}$$

Where,  $f_{CK}$  refers to the system clock of USART (PCLK1 for USART2, 3, 4, 5 and UART7, 8, and PCLK2 for USART1, 6).

Note:

1. Write access to the USART\_BAUDR register is performed before setting the UEN bit. The baud rate register values should not be altered when UEN=1.
2. When USART receiver or transmitter is disabled, the internal counter will be reset, and baud rate interrupt will occur.

Table 12-1 Error calculation for programmed baud rate

| Baud rate fPCLK=36MHz |       |         | fPCLK=72MHz                                |         |         |                                            |         |
|-----------------------|-------|---------|--------------------------------------------|---------|---------|--------------------------------------------|---------|
| No.                   | Kbps  | Actual  | Value programmed in the baud rate register | Error % | Actual  | Value programmed in the baud rate register | Error % |
| 1                     | 2.4   | 2.4     | 15000                                      | 0%      | 2.4     | 30000                                      | 0%      |
| 2                     | 9.6   | 9.6     | 3750                                       | 0%      | 9.6     | 7500                                       | 0%      |
| 3                     | 19.2  | 19.2    | 1875                                       | 0%      | 19.2    | 3750                                       | 0%      |
| 4                     | 57.6  | 57.6    | 625                                        | 0%      | 57.6    | 1250                                       | 0%      |
| 5                     | 115.2 | 115.384 | 312                                        | 0.15%   | 115.2   | 625                                        | 0%      |
| 6                     | 230.4 | 230.769 | 156                                        | 0.16%   | 230.769 | 312                                        | 0.16%   |
| 7                     | 460.8 | 461.538 | 78                                         | 0.16%   | 461.538 | 156                                        | 0.16%   |
| 8                     | 921.6 | 923.076 | 39                                         | 0.16%   | 923.076 | 78                                         | 0.16%   |
| 9                     | 2250  | 2250    | 16                                         | 0%      | 2250    | 32                                         | 0%      |
| 10                    | 4500  | NA      | NA                                         |         | 4500    | 16                                         | 0%      |

If the baud rate is 115.2Kbps, when fPCLK=36 MHz, the baud rate register should be set as 312(0x138), and the calculated result is  $36000000 / 312 = 115384 = 115.384$ Kbps.

Error: (actual value – theoretical value) / theoretical value \* 100%:  $(115.384 - 115.2) / 115.2 * 100\% = 0.15\%$ .

## 12.7 Transmitter

### 12.7.1 Introduction

USART transmitter has its individual TEN control bit. The transmitter and receiver share the same baud rate that is programmable. There is a transmit data buffer (TDR) and a transmit shift register in the USART. The TDBE bit is set whenever the TDR is empty, and an interrupt is generated if the TDBEIEN is set.

The data written by software is stored in the TDR register. When the shift register is empty, the data will be moved from the TDR register to the shift register so that the data in the transmit shift register is output on the TX pin in LSB mode. The output format depends on the programmed frame format.

If synchronous transfer or clock output is selected, the clock pulse is output on the CK pin. If the hardware flow control is selected, the control signal is input on the CTS pin.

*Note:*

1. The TEN bit cannot be reset during data transfer, or the data on TX pin will be corrupted.
2. After the TEN bit is enabled, the USART will automatically send an idle frame.

### 12.7.2 Transmitter configuration

1. USART enable: set UEN= 1.
2. Full-duplex/half-duplex configuration: Refer to full-duplex/half-duplex selector for more information (Section 12.2).
3. Mode configuration: Refer to mode selector for more information (Section 12.3).
4. Frame format configuration: Refer to frame format for more information (Section 12.4).
5. Interrupt configuration: Refer to interrupt generation for more information (Section 12.10).
6. DMA transmission configuration: If the DMA mode is selected, the DMATEN bit (bit [7] in the USART\_CTRL3 register) is set, and configure DMA register accordingly.
7. Baud rate configuration: Refer to baud rate generation for details (Section 12.6).
8. Transmitter enable: When the TEN bit is set, the USART transmitter will send an idle frame.
9. Write operation: Wait until the TDBE bit is set, the data to be transferred will be loaded into the USART\_DT register (this operation will clear the TDBE bit). Repeat this operation in non-DMA mode.
10. After the last data expected to be transferred is written, wait until the TDC bit is set, indicating the end of transfer. The USART cannot be disabled before the flag is set; otherwise, transfer error will occur.
11. When TDC=1, read access to the USART\_STS register and write access to the USART\_DT register will clear the TDC bit; this bit can also be cleared by writing “0”, but this is valid only in DMA mode.

Figure 12-10 Variations when transmitting TDC/TDBE



*Note:* the interval period between two consecutive data transfers is fixed at 2 PCLK cycles. For example, if APB clock = 72MHz, and clock period = 13.88ns, after the completion of the stop bit of the last data, the TX pin is able to send the subsequent data only after a delay of  $13.88 * 2 = 27.76\text{ns}$ .

## 12.8 Receiver

### 12.8.1 Introduction

USART receiver has its individual REN control bit (bit [2] in the USART\_CTRL1 register). The transmitter and receiver share the same baud rate that is programmable. There is a receive data buffer (RDR) and a receive shift register in the USART.

The data is input on the RX pin of the USART. When a valid start bit is detected, the receiver ports the data received into the receive shift register in LSB mode. After a full data frame is received, based on the programmed frame format, it will be moved from the receive shift register to the receive data buffer, and the RDBF is set accordingly. An interrupt is generated if the RDBFIEN is set.

If hardware flow control is selected, the control signal is output on the RTS pin.

During data reception, the USART receiver will detect whether there are errors to occur, including framing error, overrun error, parity check error or noise error, depending on software configuration, and whether there are interrupts to generate using the interrupt enable bits.

### 12.8.2 Receiver configuration

Configuration procedure:

1. USART enable: set UEN=1.
2. Full-duplex/half-duplex configuration: Refer to full-duplex/half-duplex selector for more information (Section 12.2).
3. Mode configuration: Refer to mode selector for more information (Section 12.3).
4. Frame format configuration: Refer to frame format for more information (Section 12.4).
5. Interrupt configuration: Refer to interrupt generation for more information (Section 12.10).
6. Reception using DMA: If the DMA mode is selected, the DMAREN bit is set, and configure DMA register accordingly.
7. Baud rate configuration: Refer to baud rate generation for details (Section 12.6).
8. Receiver enable: set REN=1.

Character reception:

- The RDBF bit is set. It indicates that the content of the shift register is transferred to the RDR (Receiver Data Register). In other words, data is received and can be read (including its associated error flags).
- An interrupt is generated when the RDBFIEN bit is set.
- The error flag is set when a framing error, noise error or overrun error is detected during reception.
- In DMA mode, the RDBF bit is set after every byte is received, and it is cleared when the data register is read by DMA.
- In non-DMA mode, the RDBF bit is cleared when read access to the USART\_DT register by software. The RDBF flag can also be cleared by writing “0” to it. The RDBF bit must be cleared before the end of next frame reception to avoid overrun error.

Break frame reception:

- Non-LIN mode: It is handled as a framing error, and the FERR is set. An interrupt is generated if the corresponding interrupt bit is enabled. Refer to framing error described below for details.
- LIN mode: It is handled as a break frame, and the BFF bit is set. An interrupt is generated if the BFIEN is set.

Idle frame reception:

- USART receiver processes this idle frame as a data frame, and the IDLEF bit is set. An interrupt is generated when the IDLEIEN is set.

When a framing error occurs:

- The FERR bit is set.
- The USART receiver moves the invalid data from the receive shift register to the receive data buffer.
- In non-DMA mode, both FERR and RDBF are set at the same time. The latter will generate an interrupt. In DMA mode, an interrupt is generated if the ERRIEN is set.

When an overrun error occurs:

- The ROERR bit is set.
- The data in the receive data buffer is not lost. The previous data is still available when the USART\_DT register is read.
- The content in the receive shift register is overwritten. Afterwards, any data received will be lost.
- An interrupt is generated if the RDBFIEN bit is set or both ERRIEN and DMAREN bits are set.
- The ROERR bit is cleared by reading the USART\_STS register and then reading the USART\_DT register in order.

Note: If the ROERR bit is set, it indicates that at least one piece of data is lost, with two possibilities:

- If RDBF=1, it indicates that the last valid data is still stored in the receive data buffer and can be read.
- If RDBF=0, it indicates that the last valid data in the receive data buffer has already been read.

Note: The REN bit cannot be reset during data reception, or the byte that is currently being received will be lost.

### 12.8.3 Start bit and noise detection

A start bit detection occurs when the REN bit is set. With the oversampling techniques, the USART receiver samples data on the 3rd, 5th, 7th, 8th, 9th and 10th bits to detect the valid start bit and noise. The table below shows the data sampling over start bit and noise detection.

Table 12-2 Data sampling over start bit and noise detection

| Sampled value (3·5·7) | Sampled value (8·9·10) | NERR bit | Start bit validity |
|-----------------------|------------------------|----------|--------------------|
| 000                   | 000                    | 0        | Valid              |
| 001/010/100           | 001/010/100            | 1        | Valid              |
| 001/010/100           | 000                    | 1        | Valid              |
| 000                   | 001/010/100            | 1        | Valid              |
| 111/110/101/011       | Any value              | 0        | Invalid            |
| Any value             | 111/110/101/011        | 0        | Invalid            |

Note: If the sampling values on the 3rd, 5th, 7th, 8th, 9th, and 10th bits do not match the above mentioned requirements, the USART receiver does not think that a correct start bit is received, and thus it will abort the start bit detection and return to idle state waiting for a falling edge.

The USART receiver has the ability to detect noise. In the non-synchronous mode, the USART receiver samples data on the 7th, 8th and 9th bits, with its oversampling techniques, to distinguish valid data input from noise based on different sampling values, and recovers data as well as sets NERR (Noise Error Flag) bit.

Table 12-3 Data sampling over valid data and noise detection

| Sampled value | NERR bit | Received bit value | Data validity |
|---------------|----------|--------------------|---------------|
| 000           | 0        | 0                  | Valid         |
| 001           | 1        | 0                  | Invalid       |
| 010           | 1        | 0                  | Invalid       |
| 011           | 1        | 1                  | Invalid       |
| 100           | 1        | 0                  | Invalid       |
| 101           | 1        | 1                  | Invalid       |
| 110           | 1        | 1                  | Invalid       |
| 111           | 0        | 1                  | Valid         |

USART is able to receive data under the maximum allowable deviation condition. Its value depends on the DBN[1:0] of the USART\_CTRL1 register and the DIV[3: 0] of the USART\_BAUDR register.

Note: The maximum allowable deviations stated in the table below are calculated based on 115.2Kbps. The actual deviations may vary with the settings of baud rate. In other words, the greater the baud rate is, the smaller the maximum allowable deviation; in contrast, when the baud rate gets smaller, the maximum allowable deviation will get bigger.

Table 12-4 Maximum allowable deviation

| DBN[1:0] | DIV[3:0] = 0 | DIV[3:0] != 0 |
|----------|--------------|---------------|
| 00       | 3.75%        | 3.33%         |
| 01       | 3.41%        | 3.03%         |
| 10       | 4.16%        | 3.7%          |

When noise is detected in a data frame:

- The NERR bit is set at the same time as the RDBF bit.
- The invalid data is transferred from the receive shift register to the receive data buffer.
- No interrupt is generated in non-DMA mode. However, since the NERR bit is set at the same time as the RDBF bit, the RDBF bit will generate an interrupt. In DMA mode, an interrupt will be issued if the ERRIEN is set.
- The NERR bit is cleared by reading the USART\_STS register and the reading the USART\_DT register in order.

Figure 12-11 Data sampling for noise detection



## 12.9 Tx/Rx swap

When the TRPSWAP (bit [15] in the USART\_CTRL2 register) is set, Tx/Rx pins can be swapped. Two common scenes are listed below:

- If Tx/Rx are reversed while the user attempts to connect the device externally to a RS-232 chip, they can be swapped by setting the TRPSWAP bit, without the need of hardware intervention.
- If the user only connects the master Tx to the slave Rx in full-duplex mode, the Tx/Rx can be interchangeable with the TRPSWAP bit after the master and slave are swapped, without the need of hardware intervention.

Figure 12-12 Tx/Rx swap



Note: The TRPSWAP (USART\_CTRL2[15]) can be modified only when the USART is disabled (UEN=0).

## 12.10 Interrupts

USART interrupt generator serves as a control center of USART interrupts. It is used to monitor the interrupt source inside the USART in real time and the generation of interrupts according to the programmed interrupt control bits. The table below shows the USART interrupt source and interrupt enable control bit. An interrupt will be generated over an event when the corresponding interrupt enable bit is set.

Table 12-5 USART interrupt requests

| Interrupt event                              | Event flag          | Enable bit |
|----------------------------------------------|---------------------|------------|
| Transmit data register empty                 | TDBE                | TDBEIEN    |
| CTS flag                                     | CTSCF               | CTSCFIEN   |
| Transmit complete                            | TDC                 | TDCIEN     |
| Receive data buffer full                     | RDBF                | RDBFIEN    |
| Receive overflow error                       | ROERR               |            |
| Idle flag                                    | IDLEF               | IDLEIEN    |
| Parity error                                 | PERR                | PERRIEN    |
| Break frame flag                             | BFF                 | BFIEN      |
| Noise error, overflow error or framing error | NERR, ROERR or FERR | ERRIEN(1)  |
| Receiver timeout detection                   | RTODF               | RTODIE     |
| Byte match detection                         | CMDF                | CMDIE      |

Figure 12-13 USART interrupt map diagram



## 12.11 I/O pin control

The following five interfaces are used for USART communication.

RX: Serial data input.

TX: Serial data output. In single-wire half-duplex mode and Smartcard mode, the TX pin is used as an I/O for data transmission and reception.

CK: Transmitter clock output. The output CLK phase, polarity and frequency are programmable.

CTS: Transmitter input. Send enable signal in hardware flow control mode.

RTS: Receiver output. Send request signal in hardware flow control mode.

## 12.12 USART registers

Table 12-6 USART register map and reset value

| Register  | Offset | Reset value |
|-----------|--------|-------------|
| USART_STS | 0x00   | 0x00C0      |
| USART_DT  | 0x04   | 0x0000      |

|             |      |        |
|-------------|------|--------|
| USART_BAUDR | 0x08 | 0x0000 |
| USART_CTRL1 | 0x0C | 0x0000 |
| USART_CTRL2 | 0x10 | 0x0000 |
| USART_CTRL3 | 0x14 | 0x0000 |
| USART_GDIV  | 0x18 | 0x0000 |
| USART_RTOV  | 0x1C | 0x0000 |
| USART_IFC   | 0x20 | 0x0000 |

## 12.12.1 Status register (USART\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                               |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:18 |          |             |      |                                                                                                                                                                                                                                                                                                           |
| Bit 16:12 | Reserved | 0x000000    | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                   |
| Bit 10    |          |             |      |                                                                                                                                                                                                                                                                                                           |
| Bit 17    | CMDF     | 0           | r    | Byte match detection flag<br>This bit is set by hardware when the byte defined by ID[7:0] is received. It is cleared by software.<br>0: No byte received<br>1: Byte received                                                                                                                              |
| Bit 11    | RTODF    | 0           | r    | Receiver timeout detection flag<br>This bit is set by hardware when the timeout value reaches the programmed value in RTOV register and without any communication. It is cleared by software.<br>0: No timeout detected<br>1: Timeout detected                                                            |
| Bit 9     | CTSCF    | 0x0         | rw0c | CTS change flag<br>This bit is set by hardware when the CTS status line changes. It is cleared by software.<br>0: No change on the CTS status line<br>1: A change occurs on the CTS status line                                                                                                           |
| Bit 8     | BFF      | 0x0         | rw0c | Break frame flag<br>This bit is set by hardware when a break frame is detected. It is cleared by software.<br>0: No break frame is detected<br>1: A break frame is detected                                                                                                                               |
| Bit 7     | TDBE     | 0x1         | ro   | Transmit data buffer empty<br>This bit is set by hardware when the transmit data buffer is empty. It is cleared by a write operation to the USART_DT register.<br>0: Data is not transferred to the shift register<br>1: Data is transferred to the shift register                                        |
| Bit 6     | TDC      | 0x1         | rw0c | Transmit data complete<br>This bit is set by hardware at the end of transmission. It is cleared by software (Option 1: Read access to the USART_STS and then write access to the USART_DT register; Option 2: Write "0" to this bit).<br>0: Transmission is not completed<br>1: Transmission is completed |
| Bit 5     | RDBF     | 0x0         | rw0c | Receive data buffer full<br>This bit is set by hardware when the data is transferred from the shift register to the USART_DT register. It is cleared by software (Option 1: Read access to the USART_DT register; Option 2: Write "0" to the bit).<br>0: Data is not received                             |

|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | 1: Data is received                                                                                                                                                                                                                                                                                                                                                                |
|       |       |     |    | Idle flag                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 4 | IDLEF | 0x0 | ro | This bit is set by hardware when an idle line is detected. It is cleared by software (read access to the USART_STS register and then read access to the USART_DT register).<br>0: No idle line is detected<br>1: Idle line is detected                                                                                                                                             |
|       |       |     |    | Receiver overflow error                                                                                                                                                                                                                                                                                                                                                            |
| Bit 3 | ROERR | 0x0 | ro | This bit is set by hardware when the data is received while the RDNE is still set. It is cleared by software (read access to the USART_STS register and then read access to the USART_DT register).<br>0: No overflow error<br>1: Overflow error is detected<br>Note: When this bit is set, the DT register content will not be lost, but the subsequent data will be overwritten. |
|       |       |     |    | Noise error                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 2 | NERR  | 0x0 | ro | This bit is set by hardware when noise is detect on a received frame. It is cleared by software (read access to the USART_STS register and then read access to the USART_DT register).<br>0: No noise is detected<br>1: Noise is detected                                                                                                                                          |
|       |       |     |    | Framing error                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 1 | FERR  | 0x0 | ro | This bit is set by hardware when a stop bit error (low level), excessive noise or break frame is detected. It is cleared by software (read access to the USART_STS register and then read access to the USART_DT register).<br>0: No framing error is detected<br>1: Framing error is detected                                                                                     |
|       |       |     |    | Parity error                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 0 | PERR  | 0x0 | ro | This bit is set by hardware when parity error occurs. It is cleared by software (read access to the USART_STS register and then read access to the USART_DT register).<br>0: No parity error occurs<br>1: Parity error occurs                                                                                                                                                      |

## 12.12.2 Data register (USART\_DT)

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                        |
|----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:9 | Reserved | 0x000000    | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                            |
| Bit 8:0  | DT       | 0x000       | rw   | Data value<br>This register provides read and write function. When transmitting with the parity bit enabled, the value written in the MSB bit will be replaced by the parity bit. When receiving with the parity bit enabled, the value in the MSB bit is the received parity bit. |

## 12.12.3 Baud rate register (USART\_BAUDR)

Note: If TEN and REN bits are disabled, the baud counter stops counting.

| Bit       | Name     | Reset value | Type | Description                                      |
|-----------|----------|-------------|------|--------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Forced to 0 by hardware                          |
| Bit 15:0  | DIV      | 0x0000      | rw   | Divider<br>This field defines the USART divider. |

## 12.12.4 Control register 1 (USART\_CTRL1)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                  |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:29 | Reserved | 0x00000     | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                                      |
|           |          |             |      | Data bit number<br>This bit, along with the DBN0 bit, is used to program the number of data bits.<br>10: 7 data bits<br>00: 8 data bits<br>01: 9 data bits<br>11: Write operation forbidden                                                                                                                                                                  |
| Bit 28    | DBN1     | 0x0         | rw   | Note: When parity check is enabled, the number of valid data bits will be decremented by one bit, and the MSB of the data bit is replaced with parity check bit.                                                                                                                                                                                             |
|           |          |             |      | Receiver timeout detection enable                                                                                                                                                                                                                                                                                                                            |
| Bit 27    | RTODEN   | 0           | rw   | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                    |
|           |          |             |      | Receiver timeout detection interrupt enable                                                                                                                                                                                                                                                                                                                  |
| Bit 26    | RTODIE   | 0           | rw   | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                    |
|           |          |             |      | Transmit start delay time<br>In RS485 mode, the first data (in sequential transmit mode) is transmitted after a period of time of being written so as to ensure that the transfer direction of the external transmitter/receiver switches back to transmit. This time depends on the TSDT value, in unit of 1/16 baud rate.                                  |
| Bit 25:21 | TS DT    | 0x00        | rw   | Transmit complete delay time<br>In RS485 mode, a period of time (delay) is needed before the last data transfer is complete even if the last STOP bit has been transferred. This time duration allows the transfer direction of the external receiver/transmitter to switch back to receive. This time depends on the TCDT value, in unit of 1/16 baud rate. |
| Bit 15    | Reserved | 0           | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                   |
|           |          |             |      | Character match detection interrupt enable                                                                                                                                                                                                                                                                                                                   |
| Bit 14    | CMDIE    | 0           | rw   | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                    |
|           |          |             |      | USART enable                                                                                                                                                                                                                                                                                                                                                 |
| Bit 13    | UEN      | 0x0         | rw   | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                    |
|           |          |             |      | Data bit number<br>This bit, along with DBN1, is used to program the number of data bits<br>10: 7 data bits<br>00: 8 data bits<br>01: 9 data bits<br>11: Write operation forbidden                                                                                                                                                                           |
|           |          |             |      | Note: When parity check is enabled, the number of valid data bits will be decremented by one bit, and the MSB of the data bit is replaced with parity check bit.                                                                                                                                                                                             |
| Bit 12    | DBN0     | 0x0         | rw   | Wakeup mode<br>This bit determines the way to wake up from silent mode.<br>0: Waken up by idle line<br>1: Waken up by ID match                                                                                                                                                                                                                               |

|        |         |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|---------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         |     |    | Parity enable                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 10 | PEN     | 0x0 | rw | This bit is used to enable hardware parity control (generation of parity bit for transmission; detection of parity bit for reception). When this bit is enabled, the MSB bit of the transmitted data is replaced with the parity bit; check whether the parity bit of the received data is correct.<br>0: Disabled<br>1: Enabled                                                                                                                     |
|        |         |     |    | Parity selection                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 9  | PSEL    | 0x0 | rw | This bit selects the odd or even parity after the parity control is enabled.<br>0: Even parity<br>1: Odd parity                                                                                                                                                                                                                                                                                                                                      |
|        |         |     |    | PERR interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 8  | PERRIEN | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         |     |    | TDBE interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 7  | TDBEIEN | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         |     |    | TDCIEN interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 6  | TDCIEN  | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         |     |    | RDBFIEN interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 5  | RDBFIEN | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         |     |    | IDLE interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 4  | IDLEIEN | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         |     |    | Transmitter enable                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 3  | TEN     | 0x0 | rw | This bit enables the transmitter.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                       |
|        |         |     |    | Receiver enable                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 2  | REN     | 0x0 | rw | This bit enables the receiver.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                          |
|        |         |     |    | Receiver mute                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 1  | RM      | 0x0 | rw | This bit determines if the receiver is in mute mode or not. It is set or cleared by software. When the idle line is used to wake up from mute mode, this bit is cleared by hardware after wake up. When the address match is used to wake up from mute mode, it is cleared by hardware after wake up. When address mismatches, this bit is set by hardware to enter mute mode again.<br>0: Receiver is in active mode<br>1: Receiver is in mute mode |
|        |         |     |    | Send break frame                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 0  | SBF     | 0x0 | rw | This bit is used to send a break frame. It can be set or cleared by software. Generally speaking, it is set by software and cleared by hardware at the end of break frame transmission.<br>0: No break frame is transmitted<br>1: Break frame is transmitted                                                                                                                                                                                         |

## 12.12.5 Control register 2 (USART\_CTRL2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                            |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:28 | IDH      | 0x0         | rw   | USART identification<br>This field holds the upper four bits of USART ID. It is configurable.                                                                                                                                          |
| Bit 27:20 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                             |
| Bit 19    | MTF      | 0           | rw   | MSB transmit first<br>This bit is used to select MSB transmit first or LSB transmit first.<br>0: LSB<br>1: MSB<br>Note: Parity check is not available when MTF is enabled.                                                             |
| Bit 18    | DTREV    | 0           | rw   | DT register polarity reverse<br>0: 1=H, 0=L<br>1: 1=L, 0=H                                                                                                                                                                             |
| Bit 17    | TXREV    | 0           | rw   | TX polarity reverse<br>0:VDD=1/idle,Gnd=0/mark<br>1:VDD=0/mark,Gnd=1/idle                                                                                                                                                              |
| Bit 16    | RXREV    | 0           | rw   | RX polarity reverse<br>0:VDD=1/idle,Gnd=0/mark<br>1:VDD=0/mark,Gnd=1/idle                                                                                                                                                              |
| Bit 15    | TRPSWAP  | 0x0         | rw   | Transmit/receive pin swap<br>0: Transmit/receive pin is not swappable<br>1: Transmit/receive pin is swappable                                                                                                                          |
| Bit 14    | LINEN    | 0x0         | rw   | LIN mode enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                           |
| Bit 13:12 | STOPBN   | 0x0         | rw   | STOP bit number<br>These bits are used to program the number of stop bits.<br>00: 1 stop bit<br>01: 0.5 stop bit<br>10: 2 stop bits<br>11: 1.5 stop bits                                                                               |
| Bit 11    | CLKEN    | 0x0         | rw   | Clock enable<br>This bit is used to enable the clock pin for synchronous mode or Smartcard mode.<br>0: Disabled<br>1: Enabled                                                                                                          |
| Bit 10    | CLKPOL   | 0x0         | rw   | Clock polarity<br>In synchronous mode or Smartcard mode, this bit is used to select the polarity of the clock output on the clock pin in idle state.<br>0: Clock output low<br>1: Clock output high                                    |
| Bit 9     | CLKPHA   | 0x0         | rw   | Clock phase<br>This bit is used to select the phase of the clock output on the clock pin in synchronous mode or Smartcard mode.<br>0: Data capture is done on the first clock edge<br>1: Data capture is done on the second clock edge |
| Bit 8     | LBCP     | 0x0         | rw   | Last bit clock pulse<br>This bit is used to select whether the clock pulse of the last                                                                                                                                                 |

|         |          |     |      |                                                                                                                                                                                                                                                                        |
|---------|----------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          |     |      | data bit transmitted is output on the clock pin in synchronous mode.                                                                                                                                                                                                   |
|         |          |     |      | 0: The clock pulse of the last data bit is not output on the clock pin                                                                                                                                                                                                 |
|         |          |     |      | 1: The clock pulse of the last data bit is output on the clock pin                                                                                                                                                                                                     |
| Bit 7   | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                             |
| Bit 6   | BFIEN    | 0x0 | rw   | Break frame interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                              |
| Bit 5   | BFBN     | 0x0 | rw   | Break frame bit number<br>This bit is used to select 11-bit or 10-bit break frame.<br>0: 10-bit<br>1: 11-bit                                                                                                                                                           |
| Bit 4   | IDBN     | 0   | rw   | Identification bit number<br>This bit is used to select ID bit number.<br>0: 4-bit<br>1: Data bit – 1 bit<br>Note: When this bit is set, in 7/8/9-bit data mode, the ID bit number is the lower 6/7/8-bit (or the 5/6/7-bit if parity check is enabled), respectively. |
| Bit 3:0 | IDL      | 0x0 | rw   | USART identification (the low four bits of the USART ID)<br>This field holds the USART ID, which is configurable.                                                                                                                                                      |

*Note: These three bits (CLKPOL, CLKPHA and LBCP) should not be changed while the transmission is enabled.*

## 12.12.6 Control register 3 (USART\_CTRL3)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                             |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x000000    | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                                 |
| Bit 13:11 |          |             |      |                                                                                                                                                                                                                                                                                                                                                         |
| Bit 15    | DEP      | 0           | rw   | DE polarity selection<br>0: High level active<br>1: Low level active                                                                                                                                                                                                                                                                                    |
| Bit 14    | RS485EN  | 0           | rw   | RS485 enable<br>This bit is used to enable RS485 mode. In RS485 mode, the USART controls the transfer direction of the external receiver/transmitter through the DE signal.<br>0: RS485 mode disabled. The control signal DE output is disabled. RTS pin is used in RS232 mode.<br>1: RS485 mode enabled. The control signal DE outputs on the RTS pin. |
| Bit 10    | CTSCFIEN | 0x0         | rw   | CTSCF interrupt enable                                                                                                                                                                                                                                                                                                                                  |
| Bit 9     | CTSEN    | 0x0         | rw   | CTS enable                                                                                                                                                                                                                                                                                                                                              |
| Bit 8     | RTSEN    | 0x0         | rw   | RTS enable                                                                                                                                                                                                                                                                                                                                              |
| Bit 7     | DMATEN   | 0x0         | rw   | DMA transmit enable                                                                                                                                                                                                                                                                                                                                     |

|       |          |     |    |                                                                                                                                                        |
|-------|----------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |    | DMA receiver enable                                                                                                                                    |
| Bit 6 | DMAREN   | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                              |
|       |          |     |    | Smartcard mode enable                                                                                                                                  |
| Bit 5 | SCMEN    | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                              |
|       |          |     |    | Smartcard NACK enable                                                                                                                                  |
| Bit 4 | SCNACKEN | 0x0 | rw | This bit is used to send NACK when parity error occurs.<br>0: NACK is disabled when parity error occurs<br>1: NACK is enabled when parity error occurs |
|       |          |     |    | Single-line bidirectional half-duplex enable                                                                                                           |
| Bit 3 | SLBEN    | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                              |
|       |          |     |    | IrDA low-power mode                                                                                                                                    |
| Bit 2 | IRDALP   | 0x0 | rw | This bit is used to configure IrDA low-power mode.<br>0: Disabled<br>1: Enabled                                                                        |
|       |          |     |    | IrDA enable                                                                                                                                            |
| Bit 1 | IRDAEN   | 0x0 | rw | 0: Disabled<br>1: Enabled                                                                                                                              |
|       |          |     |    | Error interrupt enable                                                                                                                                 |
| Bit 0 | ERRIEN   | 0x0 | rw | An interrupt is generated when a framing error, overflow error or noise error occurs.<br>0: Disabled<br>1: Enabled                                     |

## 12.12.7 Guard time and divider register (USART\_GDIV)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                      |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                          |
|           |          |             |      | Smartcard guard time                                                                                                                                                                                                                                                                             |
| Bit 15:8  | SCGT     | 0x00        | rw   | This field specifies the guard time value. The transmission complete flag is set after this guard time in Smartcard mode.                                                                                                                                                                        |
|           |          |             |      | IrDA/Smartcard division                                                                                                                                                                                                                                                                          |
|           |          |             |      | In IrDA mode:<br>Bits [7:0] are invalid, which is invalid in common mode and must be set to 00000001. In low-power mode, it divides the peripheral clock to serve as the period base of the pulse width;<br>00000000: Reserved—Do not write.<br>00000001: Divided by 1<br>00000010: Divided by 2 |
| Bit 7:0   | ISDIV    | 0x00        | rw   | .....<br>In Smartcard mode:<br>The lower five bits [4:0] are valid. This division is used to divide the peripheral clock to provide clock for the Smartcard. Configured as follows:<br>00000: Reserved—Do not write.<br>00001: Divided by 2<br>00010: Divided by 4<br>00011: Divided by 6        |
|           |          |             |      | .....                                                                                                                                                                                                                                                                                            |

## 12.12.8 Receiver timeout detection register (USART\_RTOV)

| Bit       | Name     | Reset value | Type | Description                                        |
|-----------|----------|-------------|------|----------------------------------------------------|
| Bit 31:24 | Reserved | 0x00        | resd | Forced to 0 by hardware                            |
| Bit 23:0  | RTOV     | 0x00        | rw   | Receiver timeout value<br>The unit is 1-bit width. |

## 12.12.9 Interrupt flag clear register (USART\_IFC)

| Bit       | Name     | Reset value | Type | Description                           |
|-----------|----------|-------------|------|---------------------------------------|
| Bit 31:18 |          |             |      |                                       |
| Bit 16:12 | Reserved | 0x00        | resd | Forced to 0 by hardware               |
| Bit 10:0  |          |             |      |                                       |
| Bit 17    | CMDFC    | 0           | w1   | Character match detection flag clear  |
| Bit 11    | RTODFC   | 0           | w1   | Receiver timeout detection flag clear |

# 13 Serial peripheral interface (SPI)

## 13.1 SPI introduction

The SPI interface supports either the SPI protocol or the I<sup>2</sup>S protocol, depending on software configuration. This chapter gives a full description of the main features and configuration procedures of SPI used as SPI or I<sup>2</sup>S.

## 13.2 Functional overview

### 13.2.1 SPI overview

The SPI can be configured in host or slave mode depending on software configuration. It is capable of operating in full-duplex, full-duplex receive-only, half-duplex transmit-only and half-duplex receive-only modes. It also supports DMA capability for transmission and reception, and automatic CRC calculation and check functions. The SPI interface can be compatible with TI protocol by software.

#### SPI block diagram:

Figure 13-1 SPI block diagram



#### Main features as SPI:

- Programmable full-duplex or half-duplex communication
  - Full-duplex synchronous communication (supporting receive-only mode to free the transmit IO for other purposes)
  - Half-duplex synchronous communication (transfer direction is configurable by software as receive or transmit)
- Programmable master or slave mode
- Programmable CS signal handling
  - CS signal handling by hardware
  - CS signal handling by software
- Programmable 8-bit or 16-bit frame format

- Programmable communication frequency and division factors (can be up to  $f_{PCLK}/2$ )
  - Programmable clock polarity and phase
  - Programmable data transfer order (MSB-first or LSB-first)
- Programmable error interrupt flags (CS pulse error, receiver overflow error, master mode error and CRC error)
- Programmable transmit data buffer empty interrupt and receive data buffer full interrupt
- Support transmission and reception with DMA
- Support hardware CRC transmission and check
- Busy status flag
- Compatible with the TI protocol

#### Clock phase and clock polarity

Four possible timing relationships may be chosen by setting the CLKPOL and CLKPHA bits in the SPI\_CTRL1 register. The CLKPOL (clock polarity) bit controls the steady state value of the clock when no data is being transferred. This bit affects both master and slave modes. If CLKPOL is cleared, the SCK pin has a low-level idle state. If CLKPOL is set to 1, the SCK pin has a high-level idle state.

If the CLKPHA (clock phase) bit is set to 1, the second edge on the SCK pin (falling edge if the CLKPOL bit is reset, rising edge if the CLKPOL bit is set) will sample data bits. Data are latched on the occurrence of the second clock transition. If the CLKPHA bit is reset, the first edge on the SCK pin (falling edge if CLKPOL bit is set, rising edge if CLKPOL bit is reset) will sample data bits. Data are latched on the occurrence of the first clock transition.

Figure 13-2 Data clock timing diagram



### 13.2.2 Full-duplex/half-duplex mode selector

When used as an SPI interface (through software configuration), it is capable of operating in four synchronous modes: two-wire unidirectional full-duplex, single-wire unidirectional receive only, single-wire bidirectional half-duplex transmit and single-wire bidirectional half-duplex receive.

**Figure 13-3 shows the two-wire unidirectional full-duplex mode and SPI IO connection:**

The SPI operates in two-wire unidirectional full-duplex mode when the SLBEN=0 and the ORA=0. In this case, the SPI supports simultaneous data transmission and reception. IOs are connected as follows:

Figure 13-3 SPI two-wire unidirectional full-duplex connection



In this scenario, whatever in master and slave mode, it is required to wait until the RDBF bit and TDBE bit is set, and BF=0 before disabling the SPI or entering power-saving mode (or disabling SPI system clock).

#### **Figure 13-4 shows the single-wire unidirectional receive-only mode and SPI IO connection**

The SPI operates in single-wire unidirectional receive-only mode when the SLBEN=0 and ORA=1. In this case, the SPI can be used as data receiver (transmission is not available). In master mode, the MISO pin receives data and the IO mapped onto MOSI is released. In slave mode, the MOSI pin receives data and the IO mapped onto MISO is released.

Figure 13-4 Single-wire unidirectional receive only in SPI master mode



Figure 13-5 Single-wire unidirectional receive only in SPI slave mode



In this scenario, for SPI in master mode, it is required to wait until the second to last RDBF bit is set and then one SPI\_CPK clock before disabling the SPI. The last RDBF must be set to 1 before entering power-saving mode (or disabling SPI system clock).

In slave mode, there is no need to check any flag before disabling the SPI. However, it is necessary to wait until the BF becomes 0 before entering power-saving mode (or disabling SPI system clock).

#### Figure 13-6 shows single-wire bidirectional half-duplex mode and SPI IO connection.

When SLBEN=1, the SPI operates in single-wire bidirectional half-duplex mode. In this case, the SPI supports data reception and transmission alternately. In master mode, the MOSI pin transmits/receives data, and IO mapped onto MISO pin is released. In slave mode, the MISO pin transmits/receives data, and IO mapped onto MOSI pin is released.

The SLBDT bit is used by software to configure transfer direction. When SLBDT=1, the SPI can be used only for data transmission; when SLBDT=0, the SPI is used for data reception only.

Figure 13-6 Single-wire bidirectional half-duplex mode



In both master and slave mode, when the SPI is selected for data transmission in single-wire bidirectional half-duplex mode, the TDBE bit must be set, and the BF must be 0 before disabling the SPI. The power-saving mode (or disabling SPI system clock) cannot be entered unless the SPI is disabled.

In master mode, when the SPI is selected for data reception in single-wire bidirectional half-duplex mode, it is required to wait until the second to last RDBF is set and then one SPI\_SCK cycle before disabling the SPI. And the last RDBF must be set to 1 before entering power-saving mode (or disabling SPI system clock).

In slave mode, when the SPI is selected for data reception in single-wire bidirectional half-duplex mode, there is no need to check any flag before disabling the SPI. However, the BT must be 0 before entering power-saving mode (or disabling SPI system clock).

### 13.2.3 Chip select controller

The Chip select controller (CS) is used to enable hardware or software control for chip select signals through software configuration. This controller is used to select master/slave device in multi-processor mode, and to avoid conflicts on data lines by enabling the SCK signal output followed by CS signal. The hardware and software configuration procedures are detailed as follows, along with their respective input/output in master and slave mode.

#### Hardware CS configuration procedures:

In master mode with CS being as an output, the CS hardware control is enabled by setting HWCSOE=1 and SWCSEN=0. If the SPI is enabled, low level is output on the CS pin. The CS signal is then released after the SPI is disabled and the transmission is complete.

In master mode with CS being as an input, the CS hardware control is enabled by setting HWCSOE=0 and SWCSEN=0. At this point, the SPI is automatically disabled by hardware and enters slave mode as soon as the CS pin low is detected by master SPI. The mode error flag (MMERR bit) is set accordingly. An interrupt is generated if ERRIE=1 is enabled. During the period of MMERR being set, the SPIEN and MSTEN cannot be set by software. The MMERR is cleared by read or write access to the SPI\_STS register followed by write access to the SPI\_CTRL1 register.

In slave mode with CS being as an input, the CS hardware control is enabled by setting HWCSOE=0 and SWCSEN=0. The slave determines whether to transmit / receive data based on the level on the CS pin. The slave is selected for data reception and transmission only when the CS pin is low.

**Software CS configuration procedures:**

In master mode with CS being as an input, the CS software control is enabled by setting SWCSEN=1. When SWCSIL=0, the SPI is automatically disabled by hardware and enters slave mode. The mode error flag (MMERR bit) is set accordingly. An interrupt is generated if ERRIE=1 is enabled. When the MMERR bit is set, the SPIEN and MSTEN bits cannot be set by software. The MMERR bit is cleared by read or write access to the SPI\_STS register followed by write access to the SPI\_CTRL1 register.

In slave mode with CS being as an input, SWCSEN=1, the CS software control is enabled. The SPI judges the CS signal with the SWCSIL bit, instead of CS pin. When SWCSIL=0, the slave is selected for data reception and transmission.

### 13.2.4 SPI\_SCK controller

The SPI protocol adopts synchronous transmission. In master mode with the SPI being used as SPI, it is necessary to generate a communication clock for data reception and transmission via the SPI interface, and the communication clock should be output to the slave via IO for data reception and transmission. In slave mode, the communication clock is provided by peripherals, and is input to the SPI interface via IO. In all, the SPI\_SCK controller is used for the generation and distribution of SPI\_SCK. Here are the configuration procedures:

**SPI\_SCK controller configuration procedures:**

- Select clock polarity and clock phase by setting the CLKPOL and CLKPHA bit.
- Select the desired PCLK frequency by setting the CRM bit, and select the desired prescaler by setting the MDIV[3: 0] bit or MDIV3EN bit.
- Select SPI as master/slave mode by setting the MSTEN bit.

Note that the clock output is activated after the SPI is enabled in master reception-only mode, and it remains present until when the SPI is disabled and the reception is complete.

### 13.2.5 CRC

The SPI interface provides separate CRC calculation unit for transmission and reception. When used as SPI through software configuration, the automatic CRC calculation and check is performed while the user is reading or writing data through either DMA or CPU. During transmission, if the received data is inconsistent with, detected by hardware, the data programmed in the SPI\_RCRC register, and such data is exactly the CRC value, the CCERR bit will be set, and an interrupt is generated if ERRIE=1 is enabled.

The CRC function and configuration procedures of the SPI are described as follows.

**CRC configuration procedures**

- Configure CRC calculation polynomial by setting the SPI\_CPOLY register.
- Enable CRC calculation by setting the CCEN bit. This operation will reset the SPI\_RCRC and SPI\_TCRC registers.
- Select if or when the NTC bit is set, depending on DMA or CPU data register. See the following descriptions.

**Transmission using DMA**

When DMA is used to write the data to be transmitted, if the CCEN bit is enabled, the hardware calculates the CRC value automatically according to the value in the SPI\_CPOLY register and each transmitted data, and sends the CRC value at the end of the last data transmission. This CRC value is the value of the SPI\_TCRC register.

**Reception using DMA**

When DMA is used to read the to-be-received data, if the CCEN bit is enabled, the hardware calculates the CRC value automatically according to the value in the SPI\_CPOLY register and each received data, and waits until the completion of CRC data reception at the end of the last data reception before comparing the received CRC value with the value programmed in the SPI\_RCRC register. If check error occurs, the CCERR flag is set, and an interrupt is generated if the ERRIE bit is enabled.

Figure 13-7 DMA data transfer with CRC enabled



### Transmission using CPU

Unlike DMA mode, after software writing the last data to be transmitted, the CPU mode sets the NTC bit before the end of the last data transmission.

### Reception using CPU

In two-wire unidirectional full-duplex mode, the CRC calculation and check in CPU reception mode will be completed automatically by following CPU transmission mode to operate the NTC bit.

In single-wire unidirectional reception-only mode and single-wire bidirectional reception-only mode, it is required to set the NTC bit by software before the last data is received when the second-to-last data is already received.

## 13.2.6 DMA transfer

The SPI interface supports the use of DMA for data write and read. Refer to the following configuration procedures for details in this regard.

Special attention should be paid to here:

When the CRC calculation and check is enabled, the number of data transferred by DMA is configured to be the number of the to-be-sent data, while the number of data read with DMA is configured as the number of the data to receive. Then the hardware will send CRC automatically at the end of full transfer, and the receiver will perform automatic CRC check. Note that the received CRC data will be moved into the SPI\_DT register by hardware, the RDBF is set, and DMA read request will be issued if then DAM transfer feature is enabled. Hence, it is recommended to read the SPI\_DT register by software to fetch the CRC value after the completion of CRC data reception, in order to avoid the upcoming transfer error.

### Transmission with DMA

- Select a DMA channel for the current SPI according to DMA channel map table described in DMA chapter.
- Configure the destination of DMA transfer: Configure the SPI\_DT register address as the destination address bit of DMA transfer in the DMA control register. Data will be sent to this address after transmit request is received by DMA.
- Configure the source of DMA transfer: Configure the memory address as the source of DMA transfer in the DMA control register. Data will be loaded into the SPI\_DT register from the memory address after transmit request is received by DMA.
- Configure the total number of bytes to be transferred in the DMA control register.

- Configure the channel priority of DMA transfer in the DMA control register.
- Configure DMA interrupt generation after half or full transfer in the DMA control register.
- Enable DMA transfer channel in the DMA control register.

#### Reception with DMA

- Select a DMA channel for the current SPI from DMA channel map table described in DMA chapter.
- Configure the destination of DMA transfer: Configure the memory address as the destination of DMA transfer in the DMA control register. Data will be loaded from the SPI\_DT register to the programmed destination after reception request is received by DMA.
- Configure the source of DMA transfer: Configure the SPI\_DT register address as the source of DMA transfer in the DMA control register. Data will be loaded from the SPI\_DT register to the programmed destination after reception request is received by DMA.
- Configure the total number of bytes to be transferred in the DMA control register.
- Configure the channel priority of DMA transfer in the DMA control register.
- Configure DMA interrupt generation after half or full transfer in the DMA control register
- Enable DMA transfer channel in the DMA control register.

### 13.2.7 TI mode overview

The SPI interface is compatible with the TI protocol. The TI mode is enabled by setting the TIEN bit to 1. In this mode, the SPI interface will generates a communication clock SPI\_CLK in accordance with the TI protocol. This means that the SPI\_CLK polarity and phase are forced to conform to the TI protocol requirements, without the need of the intervention of CLKPOL and CLKPHA bits. Thus the CLKPOL and CLKPHA bits cannot be used to change the polarity and phase of the SPI\_CLK either.

In this mode, the SPI interface will generate a CS signal in accordance with the TI protocol, meaning that the CS input and output are forced to conform to the TI protocol requirements, without the need of the intervention of SWCSEN, SWCSIL and HWCSOE bits. Thus, the SWCSEN, SWCSIL and HWCSOE bits cannot be used for CS signal management either.

After the TI mode is enabled, the SPI slave controls the MISO pin only during data transmission, meaning that its MISO pin remains Hi-Z in idle state.

After the TI mode is enabled, when in slave mode, the SPI interface is capable of detecting CS pulse errors during data transmission, and setting the CSPAS bit (It is cleared by reading the SPI\_STS) as soon as a CS pulse error is detected. At this point, the detected erroneous pulse will be ignored by the SPI. However, since there is something wrong with the CS signal, the software should disable the SPI slave and re-configure the SPI master before re-enabling the SPI slave for re-communication.

### 13.2.8 Transmitter

The SPI transmitter is clocked by SPI\_SCK controller. It can output different data frame formats, depending on software configuration. There is a SPI\_DT register in the SPI which is used to be written with the data to be transmitted. When the transmitter is clocked, the contents in the SPI\_DT register are copied into the data buffer (Unlike SPI\_DT, it is driven by SPI\_SCK, and controlled by hardware, instead of software), and sent out in order based on the programmed frame format.

Both DMA and CPU can be used for write operation. For DMA transfer, refer to DMA transfer section for more details. For CPU transfer, attention should be paid to the TDBE bit. The reset value of this bit is 1, indicating that the SPI\_DT register is empty, and an interrupt is generated if the TDBEIE bit is set. After the data is written, the TDBE is pulled low until the data are synchronized to the transmit data buffer before the TDBE is set once again, meaning that the user can be allowed to write the data to be transmitted only when the TDBE is set.

After the transmitter is configured and the SPI is enabled, the SPI is ready to send data. Before going forward, it is necessary for the users to refer to full-duplex / half-duplex chapter to get detailed configuration information, go to the Chip select controller chapter for selecting chip select mode, check the SPI\_SCK controller chapter for information on communication clock, and refer to CRC and DMA transfer chapter to configure CRC and DMA (if necessary). The recommended configuration procedures are as follows.

**Transmitter configuration procedures:**

- Configure full-duplex/half-duplex selector
- Configure chip select controller
- Configure SPI\_SCK controller
- Configure CRC (if necessary)
- Configure DMA transfer (if necessary)
- If the DMA transfer mode is not used, the software will check whether to enable transmit data interrupt (TDBEIE =1) through the TDBE bit.
- Configure frame format: select MSB/LSB mode with the LTF bit, and select 8/16-bit data with the FBN bit
- Enable SPI by setting the SPIEN

### 13.2.9 Receiver

The SPI receiver is clocked by the SPI\_SCK controller. It can receive different data frame formats through software configuration. There is a receive data buffer register, driven by the SPI\_SCK, in the SPI receiver.

At the last CLK of each transfer, data are moved from the shift register to the receive data buffer register. Then the transmitter sets the receive data complete flag to the SPI control logic unit. When the flag is detected by the SPI logic, the data in the receive data buffer are pushed into the SPI\_DT register, with the RDBF being set. This means that the data are received, and already stored into the SPI\_DT. In this case, data can be read from the SPI\_DT register. Reading the SPI\_DT register will clear the RDBF bit.

Both DMA and CPU can be used for read operation. For DMA transfer, refer to DMA transfer section for more details. For CPU transfer, attention should be paid to the RDDE bit. The reset value of this bit is 0, indicating that the SPI\_DT register is empty. If the data are received and moved into the SPI\_DT, the RDBF is set, meaning that there are data pending for read in the SPI\_DT register. Meanwhile, an interrupt is generated if the RDBFIE bit is set.

When the next received data is ready to be moved to the SPI\_DT register while the previously received data have not been read yet (RDBF=1), then the data overflow occurs. The previously receive data are not lost, but the next received data will do. At this point, the ROERR is set, and an interrupt is generated if the ERRIE is set. Reading SPI\_DT register and then the SPI\_STS register can clear the ROERR bit. The recommended configuration procedures are as follows.

**Receiver configuration procedures:**

- Configure full-duplex/half-duplex selector
- Configure chip select controller
- Configure SPI\_SCK controller
- Configure CRC (if necessary)
- Configure DMA transfer (if necessary)
- If the DMA transfer mode is not used, the software will check whether to enable receive data interrupt (RDDEIE =1) through the RDDE bit.
- Configure frame format: select MSB/LSB mode with the LTF bit, and select 8/16-bit data with the FBN bit
- Enable SPI by setting the SPIEN

### 13.2.10 Motorola mode

This section describes the SPI master/slave communication timings in full-duplex and half-duplex modes.

**Full-duplex communication – master mode**

For master side, configured as follows:

MSTEN=1: Master enable

SLBEN=0: Full-duplex mode

CLKPOL=0, CLKPHA=0: SCK idle output low, use the first edge for sampling

FBN=0: 8-bit data frame

Master sends data (MOSI): 0xaa, 0xcc, 0xaa

Slave sends data (MISO): 0xcc, 0xaa, 0xcc

Figure 13-8 Master full-duplex communications



### Full-duplex communication – slave mode

For slave side, configured as follows:

MSTEN=0: Slave enable

SLBEN=0: Full-duplex mode

CLKPOL=0, CLKPHA=0: SCK idle output low, use the first edge for sampling

FBN=0: 8-bit data frame

Master sends data (MOSI): 0xaa, 0xcc, 0xaa

Slave sends data (MISO): 0xcc, 0xaa, 0xcc

Figure 13-9 Slave full-duplex communications



### Half-duplex communication – master transmit timing

Configured as follows:

MSTEN=1: Master enable

SLBEN=1: Single line bidirectional mode

CLKPOL=0, CLKPHA=0: SCK idle output low, use the first edge for sampling

FBN=0: 8-bit data frame

Master sends data (MOSI): 0xaa, 0xcc, 0xaa

Figure 13-10 Master half-duplex transmit



### Half-duplex communication – slave receive timing

Configured as follows:

MSTEN=0: Slave enable

SLBEN=1: Single line bidirectional mode

SLBTD=0: Receive mode

CLKPOL=0, CLKPHA=0: SCK idle output low, use the first edge for sampling

FBN=0: 8-bit data frame

Slave receives data: 0xaa, 0xcc, 0xaa

Figure 13-11 Slave half-duplex receive



### Half-duplex communication – slave transmit timing

Configured as follows:

MSTEN=0: Slave enable

SLBEN=1: Single line bidirectional mode

SLBTD=1: Transmit enable

CLKPOL=0, CLKPHA=0: SCK idle output low, use the first edge for sampling

FBN=0: 8-bit data frame

Slave sends data: 0xaa, 0xcc, 0xaa

Figure 13-12 Slave half-duplex transmit



### Half-duplex communication – master receive timing

Configured as follows:

MSTEN=1: Master enable

SLBEN=1: Single line bidirectional mode

SLBTD=0: Receive enable

CLKPOL=0, CLKPHA=0: SCK idle output low, use the first edge for sampling

FBN=0: 8-bit data frame

Master receives data: 0xaa, 0xcc, 0xaa

Figure 13-13 Master half-duplex receive



### 13.2.11 TI mode communication timings

The SPI interface supports TI mode. This mode is enabled by setting TIEN=1.

In TI mode, a slight difference is present between continuous and discontinuous communication timings. When the to-be-sent data is written before the rising SCK edge corresponding to the last data of the current transmit frame, it is a continuous communication, without dummy CLK between data, and the host sends a valid CS pulse while transmitting the last data of the current frame.

Figure 13-14 TI mode continuous transfer



In TI mode, when the to-be-sent data is written between the rising and falling SCK edges corresponding to the last data of the current transmit frame, a dummy CLK exists between data.

Figure 13-15 TI mode continuous transfer with dummy CLK



Figure 13-16 TI mode discontinuous transfer



In TI mode, when the to-be-sent data is written after the falling SCK edge corresponding to the last data of the current transmit frame, the host always issues a valid SCK clock after 1T SCK + 4T PCLK cycles. If the slave still does not detect a valid CS pulse at the end of the last data of the current data frame, it disables MISO output after 1/2T SCK + 3T PCLK cycles to control MISO floating.

Figure 13-17 TI mode SCK and slave MISO release



### 13.2.12 Interrupts

Figure 13-18 SPI interrupts



### 13.2.13 IO pin control

When used as SPI, the SPI interface is connected to external devices through four pins.

- MISO: Master In/Slave Out. The pin is used to receive data from slave in SPI master mode, and transmit data in slave mode.
- MOSI: Master Out/Slave In. The pin is used to transmit data in SPI master mode, and receive data in slave mode.
- SCK: SPI communication clock. The pin serves as output (communication clock is sent to peripheral via this pin) in SPI master mode, and as input (communication clock from master is input to SPI via this pin) in SPI slave mode.
- CS: Chip Select signal. This is an optional pin which is used to select master/slave mode. Refer to CS section for more information.

## 13.3 I<sup>2</sup>S functional description

### 13.3.1 I<sup>2</sup>S introduction

The I<sup>2</sup>S is capable of operating in master receive, master transmit, and slave receive and slave transmit, depending on software configuration. These four operating modes support four audio protocols including Philips standard, MSB-aligned standard, LSB-aligned standard and PCM standard, respectively. The DMA transfer is also supported.

The combination of two I<sup>2</sup>S interfaces can be used to support I<sup>2</sup>S full-duplex mode. Refer to I<sup>2</sup>S full-duplex section for more information.

Figure 13-19 I<sup>2</sup>S block diagram**Main features when the SPI is used as I<sup>2</sup>S:**

- Programmable operating modes
  - Slave device transmission
  - Slave device reception
  - Master device transmission
  - Master device reception
- Programmable clock polarity
- Programmable clock frequency (8 KHz to 192 KHz)
- Programmable data bits (16 bits, 24 bits, 32 bits)
- Programmable channel bits (16 bits, 32 bits)
- Programmable audio protocols
  - I<sup>2</sup>S Philips standard
  - MSB-aligned standard (left-aligned)
  - LSB-aligned standard (right-aligned)
  - PCM standard (channel frame with short and long frame synchronization)
- I<sup>2</sup>S full-duplex
- DMA transfer
- Main peripheral clock with a fixed frequency of 256x Fs (audio sampling frequency)

**13.3.2 I<sup>2</sup>S full-duplex mode**

Two SPIs can be combined to support I<sup>2</sup>S full-duplex mode through the SCFG\_CFG2[31:30] bit in the SCFG register. Of the three SPIs, either SPI1 or SPI2 can be configured as full-duplex master, while the SPI2 or SPI3 can be set as full-duplex slave, which is selected through the SCFG\_CFG2[31:30] bit in the SCFG register. Once selected (combining two SPIs to achieve I<sup>2</sup>S full-duplex mode), the IO remap relations of the master remains unchanged, while the SCK and WS of the slave are connected to the SCK and WS of the master internally, with the SD line of the slave remapped onto the I<sup>2</sup>S\_SDEXT. The slave's original IO remap relations become invalid, keeping the corresponding IOs free for other purposes.

Figure 13-20 I<sup>2</sup>S full-duplex structure

I<sup>2</sup>S full-duplex master side:

It supports master or slave mode. Thus it can be programmed as a receiver or transmitter.

- I<sup>2</sup>S<sub>x</sub>\_WS is used for WS signal interaction
- I<sup>2</sup>S<sub>x</sub>\_SCK is responsible for clock signal interaction
- I<sup>2</sup>S<sub>x</sub>\_SD is used for data and information interaction on the master side

I<sup>2</sup>S full-duplex slave side:

It supports slave mode only. It can be programmed as a transmitter or receiver.

- I<sup>2</sup>S<sub>y</sub>\_WS does not take part in communication, releasing the corresponding IOs for other purposes
- I<sup>2</sup>S<sub>y</sub>\_SCK does not take part in communication, releasing the corresponding IOs for other purposes
- I<sup>2</sup>S<sub>y</sub>\_SD does not take part in communication, releasing the corresponding IOs for other purposes
- I<sup>2</sup>S\_SDEXT takes part in communication for data and information interaction on the slave side

Note: x can be 1 or 2, whereas y can be 2 or 3.

### 13.3.3 Operating mode selection

The SPI, used as I<sup>2</sup>S selector, offers multiple operating modes for selection, namely, slave device transmit, slave device receive, master device transmit and master device receive. This is done by software configuration.

#### Slave device transmission:

Set the I2SMSEL bit, and OPERSEL[1:0]=00, the I<sup>2</sup>S will work in slave device transmission mode.

Figure 13-21 I<sup>2</sup>S slave device transmission

#### Slave device reception:

Set the I2SMSEL bit, and OPERSEL[1:0]=01, the I<sup>2</sup>S will work in slave device reception mode.

Figure 13-22 I<sup>2</sup>S slave device reception**Master device transmission:**

Set the I<sup>2</sup>SMSEL bit, and OPERSEL[1:0]=10, the I<sup>2</sup>S will work in master device transmission mode.

Figure 13-23 I<sup>2</sup>S master device transmission**Master device reception:**

Set the I<sup>2</sup>SMSEL bit, and OPERSEL[1: 0]=11, the I<sup>2</sup>S will work in master device reception mode.

Figure 13-24 I<sup>2</sup>S master device reception

### 13.3.4 Audio protocol selector

As I<sup>2</sup>S interface, the SPI supports multiple audio protocols. The user can select the desired audio protocol, the number of data bits and of channel bits through the audio protocol selector by software. By controlling the WS controller automatically, the audio protocol selector outputs or detects WS signals that conform to the protocol requirements.

- Select audio protocol by setting the STDSEL bit
  - STDSLE=00: Philips standard
  - STDSLE=01: MSB-aligned standard (left-aligned)
  - STDSLE=10: LSB-aligned standard (right-aligned)
  - STDSLE=11: PCM standard
- Select PCM frame synchronization format: PCMFSEL=1 for PCM long frame synchronization, PCMFSEL=0 for short frame synchronization (this step is required when selecting PCM protocol)
- Select the number of data bits by setting the I2SDBN bit
  - I2SDBN=00: 16 bits
  - I2SDBN =01: 24 bits
  - I2SDBN =10: 32 bits
- Select the number of channel bits by setting the I2SCBN bit
  - I2SCBN =0: 16 bits
  - I2SCBN =1: 32 bits

Note: Read/Write operation mode depends on the selected audio protocol, data bits and channel bits. The following lists all possible configuration combinations and their respective read and write operation mode.

- **Philips standard, PCM standard, MSB-aligned or LSB-aligned standard, 16-bit data and 16-bit channel**

The data bits are the same as the channel bits. Each channel requires only one read/write operation from/ to the SPI\_DT register, and the number of DMA transfer is 1.
- **Philips standard, PCM standard or MSB-aligned standard, 16-bit data and 32-bit channel**

The data bits are different from the channel bits. Each channel requires only one read/write operation from/to the SPI\_DT register, and the number of DMA transfer is 1. The first 16 bits are valid data, and the remaining 16-bit are forced to 0 by hardware.
- **Philips standard, PCM standard or MSB-aligned standard, 24-bit data and 32-bit channel**

The data bits are different from the channel bits. Each channel requires two read/write operations from/to the SPI\_DT register, and the number of DMA transfer is 2. The first 16-bit channel transmits and receives the first 16-bit data, while the last 16-bit channel transmits and receives the upper 8-bit data, and the lower 8-bit data are forced to 0 by hardware.
- **Philips standard, PCM standard, MSB-aligned or LSB-aligned standard, 32-bit data and 32-bit channel**

The data bits are the same as the channel bits. Each channel requires two read/write operations from/to the SPI\_DT register, and the number of DMA transfer is 2. These 32-bit data are proceeded (transmit and reception) in two times, with 16-bit data each time.
- **LSB-aligned standard, 16-bit data and 32-bit channel**

The data bits are different from the channel bits. Each channel requires only one read/write operation from/to the SPI\_DT register, and the number of DMA transfer is 1. The last 16 bits (LSB) are valid data, while the first 16-bit data (MSB) are forced to 0 by hardware.
- **LSB-aligned standard, 24-bit data and 32-bit channel**

The data bits are different from the channel bits. Each channel requires two read/write operations from/to the SPI\_DT register, and the number of DMA transfer is 2. Of the first 16-bit data, its lower 8 bits are valid data, and the upper 8 bits are forced to 0 by software; the last 16-bit channel transmits and receives the second 16-bit data.

### 13.3.5 I2S\_CLK controller

As I<sup>2</sup>S, The audio protocols the SPI supports use synchronous transmission. In master mode, it is required to generate a communication clock for data reception and transmission on the SPI interface, and the communication clock should be output to the slave via IO for data reception and transmission. In slave mode, the communication clock is provided by master, and is input to the SPI via IO. In all, the I2S\_SCK controller is used for the generation and distribution of I2S\_SCK.

In I<sup>2</sup>S master mode, the SPI provides communication clock (CK) and main peripheral clock (MCK) shown in [Figure 13-25](#). The CK and MCK are generated by HCLK divider, and the MCK frequency division factor depends on the I2SDIV and I2SODD. The calculation formula is seen in [Figure 13-25](#).

The CK frequency division factor depends on whether to provide the main clock for peripherals. To ensure that the main clock is always 256 times the audio sampling frequency, the use of main clock and the number of channel bits should be taken into account. When the main clock is needed for peripherals, the CK should first be divided by 8 (I2SCBN=0) or 4 (I2SCBN=1), then further divided by the same frequency division factor as that of the MCK, which is called the final communication clock; When the main clock is not needed for peripherals, the CK frequency division factor is determined by I2SDIV and I2SODD, shown in [Figure 13-25](#).

Figure 13-25 CK & MCK source in master mode



In addition to the above configuration, the following table lists the values of I2SDIV and I2SODD corresponding to some specific frequencies, as well as their respective error for the users to configure the I2SDIV and I2SODD.

Table 13-1 Audio frequency precision using system clock

| SCLK (MHz) | MCL K | Target Fs (Hz) | 16-bit  |         |          |        | 32-bit  |         |          |        |
|------------|-------|----------------|---------|---------|----------|--------|---------|---------|----------|--------|
|            |       |                | I2S DIV | I2S_ODD | RealFs   | Error  | I2S DIV | I2S_ODD | RealFs   | Error  |
| 72         | No    | 192000         | 6       | 0       | 187500   | 2.34%  | 3       | 0       | 187500   | 2.34%  |
| 72         | No    | 96000          | 11      | 1       | 97826.09 | 1.90%  | 6       | 0       | 93750    | 2.34%  |
| 72         | No    | 48000          | 32      | 1       | 34615.38 | 27.88% | 11      | 1       | 48913.04 | 1.90%  |
| 72         | No    | 44100          | 25      | 1       | 44117.65 | 0.04%  | 13      | 0       | 43269.23 | 1.88%  |
| 72         | No    | 32000          | 35      | 0       | 32142.86 | 0.45%  | 17      | 1       | 32142.86 | 0.45%  |
| 72         | No    | 22050          | 51      | 0       | 22058.82 | 0.04%  | 25      | 1       | 22058.82 | 0.04%  |
| 72         | No    | 16000          | 70      | 1       | 15957.45 | 0.27%  | 35      | 0       | 16071.43 | 0.45%  |
| 72         | No    | 11025          | 102     | 0       | 11029.41 | 0.04%  | 51      | 0       | 11029.41 | 0.04%  |
| 72         | No    | 8000           | 140     | 1       | 8007.117 | 0.09%  | 70      | 1       | 7978.723 | 0.27%  |
| 72         | Yes   | 96000          | 2       | 0       | 70312.5  | 26.76% | 2       | 0       | 70312.5  | 26.76% |
| 72         | Yes   | 48000          | 3       | 0       | 46875    | 2.34%  | 3       | 0       | 46875    | 2.34%  |
| 72         | Yes   | 44100          | 3       | 0       | 46875    | 6.29%  | 3       | 0       | 46875    | 6.29%  |
| 72         | Yes   | 32000          | 4       | 1       | 31250    | 2.34%  | 4       | 1       | 31250    | 2.34%  |
| 72         | Yes   | 22050          | 6       | 1       | 21634.62 | 1.88%  | 6       | 1       | 21634.62 | 1.88%  |
| 72         | Yes   | 16000          | 9       | 0       | 15625    | 2.34%  | 9       | 0       | 15625    | 2.34%  |
| 72         | Yes   | 11025          | 13      | 0       | 10817.31 | 1.88%  | 13      | 0       | 10817.31 | 1.88%  |
| 72         | Yes   | 8000           | 17      | 1       | 8035.714 | 0.45%  | 17      | 1       | 8035.714 | 0.45%  |

### 13.3.6 DMA transfer

The SPI supports the use of DMA for write and read operations. Whether used as SPI or I<sup>2</sup>S, read/write request using DMA comes from the same peripheral. As a result, their configuration procedure are the same, described as follows.

#### Transmission with DMA

- Select a DMA channel for the current SPI from DMA channel map table described in DMA chapter.
- Configure the destination of DMA transfer: Configure the SPI\_DT register address as the destination address bit of DMA transfer in the DMA control register. Data will be sent to this address after transmit request is received by DMA.
- Configure the source of DMA transfer: Configure the memory address as the source of DMA transfer in the DMA control register. Data will be loaded into the SPI\_DT register from the memory address after transmit request is received by DMA.
- Configure the total number of bytes to be transferred in the DMA control register.
- Configure the channel priority of DMA transfer in the DMA control register.
- Configure DMA interrupt generation after half or full transfer in the DMA control register.
- Enable DMA transfer channel in the DMA control register.

#### Reception with DMA

- Select a DMA channel for the current SPI from DMA channel map table described in DMA chapter.
- Configure the destination of DMA transfer: Configure the memory address as the destination of DMA transfer in the DMA control register. Data will be loaded from the SPI\_DT register to the programmed destination after reception request is received by DMA.
- Configure the source of DMA transfer: Configure the SPI\_DT register address as the source of DMA transfer in the DMA control register. Data will be loaded from the SPI\_DT register to the programmed destination after reception request is received by DMA.
- Configure the total number of bytes to be transferred in the DMA control register.
- Configure the channel priority of DMA transfer in the DMA control register.
- Configure DMA interrupt generation after half or full transfer in the DMA control register
- Enable DMA transfer channel in the DMA control register.

### 13.3.7 Transmitter/Receiver

Whether used as SPI or I<sup>2</sup>S, there is no difference for CPU. The SPI (in whatever mode) shares the same base address, the same SPI\_DT register, the same transmitter and receiver. The SPI transmitter and receiver are responsible for sending and receiving the desired data frame according to the configuration of the communication controller. Thus status flags such as TDBE, RDBF and ROERR, and their interrupt enable bits including TDBEIE, RDBFIE and ERRIE are identical.

#### Special attention must be paid to:

- CRC check is not available on the I<sup>2</sup>S. Any operations related to CRC, including CCERR flag and corresponding interrupts, are not supported.
- I<sup>2</sup>S protocol needs decode the current channel status. The ACS bit is used to judge whether the current transfer occurs on the left channel (ACS=0) or the right channel (ACS=1).
- TUERR bit indicates whether an underrun occurs. TUERR=1 means an underrun error occurs on the transmitter. An interrupt is generated when the ERRIE is set.
- Read/write operation to the SPI\_DT register is different under different audio protocols, data bits and channel bits. Refer to the audio protocol selector section for more information.
- Pay more attention to the I<sup>2</sup>S disable operation under different configurations, shown as follows:
  - I2SDBN=00, I2SCBN=1, STDSLE=10: wait for the second-to-last RDBF=1 and 17 CK cycles before disabling the I<sup>2</sup>S.
  - I2SDBN=00, I2SCBN=1, STDSLE=00 or STDSLE=01 or STDSLE=11: wait for the last RDBF=1 and one CK cycles before the I<sup>2</sup>S.

— I2SDBN, I2SCBN, STDSLE combination: wait for the second-to-last RDBF=1 and one CK cycles before disabling the I<sup>2</sup>S.

#### I<sup>2</sup>S transmitter configuration procedures:

- Configure operation mode selector
- Configure audio protocol selector
- Configure I2S\_SCK controller
- Configure DMA transfer (if necessary)
- Set the I2SEN bit to enable I<sup>2</sup>S
- Follow above steps to configure the I<sup>2</sup>SxEXT (For I<sup>2</sup>S full-duplex mode )

#### I<sup>2</sup>S receiver configuration procedures:

- Configure operation mode selector
- Configure audio protocol selector
- Configure I2S\_SCK controller
- Configure DMA transfer (if necessary)
- Set the I2SEN bit to enable I<sup>2</sup>S
- Follow above steps to configure the I<sup>2</sup>SxEXT (For I<sup>2</sup>S full-duplex mode )

### 13.3.8 I<sup>2</sup>S communication timings

I<sup>2</sup>S can address four different audio standards: Philips standard, the MSB-aligned (left-aligned) and the LSB-aligned (right-aligned) standards, and the PCM standard. Figure 13-25 shows their respective timings.

Figure 13-26 Audio standard timings



### 13.3.9 Interrupts

Figure 13-27 I<sup>2</sup>S interrupts

### 13.3.10 IO pin control

The I<sup>2</sup>S needs three pins for transfer operation, namely, the SD, WS and CK. The MCLK pin is also required if there is a need to provide main clock for peripherals. Considering the SPI interface cannot be used as I<sup>2</sup>S and SPI at the same time, the I<sup>2</sup>S shares some pins with SPI, described as follows:

- SD: Serial data (mapped on the MOSI pin) for bidirectional data transmission and reception.
- WS: Word select (mapped on the CS pin) for data control signal output in master mode, and input in slave mode.
- CK: Communication clock (mapped on the SCK pin) as clock signal output in master mode, and input in slave mode.
- MCLK: Master clock (mapped independently) is used to provide main clock for peripherals. The frequency of output clock signal is set to 256x Fs (audio sampling frequency)

## 13.4 SPI registers

These peripheral registers must be accessed by words (32 bits).

Table 13-2 SPI register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| SPI_CTRL1   | 0x00   | 0x0000      |
| SPI_CTRL2   | 0x04   | 0x0000      |
| SPI_STS     | 0x08   | 0x0002      |
| SPI_DT      | 0x0C   | 0x0000      |
| SPI_CPOLY   | 0x10   | 0x0007      |
| SPI_RCRC    | 0x14   | 0x0000      |
| SPI_TCRC    | 0x18   | 0x0000      |
| SPI_I2SCTRL | 0x1C   | 0x0000      |
| SPI_I2SCLK  | 0x20   | 0x0002      |

### 13.4.1 SPI control register 1 (SPI\_CTRL1) (Not used in I<sup>2</sup>S mode)

| Bit      | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                           |
|----------|--------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15   | SLBEN  | 0x0         | rw   | Single line bidirectional half-duplex enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                             |
| Bit 14   | SLBTD  | 0x0         | rw   | Single line bidirectional half-duplex transmission direction<br>This bit and the SLBEN bit together determine the data output direction in "Single line bidirectional half-duplex" mode.<br>0: Receive-only mode<br>1: Transmit-only mode                                                                                                             |
| Bit 13   | CCEN   | 0x0         | rw   | CRC calculation enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                   |
| Bit 12   | NTC    | 0x0         | rw   | Transmit CRC next<br>When this bit is set, it indicates that the next data transferred is CRC value.<br>0: Next transmitted data is the normal value<br>1: Next transmitted data is CRC value                                                                                                                                                         |
| Bit 11   | FBN    | 0x0         | rw   | Frame bit num<br>This bit is used to configure the number of data frame bit for transmission/reception.<br>0: 8-bit data frame<br>1: 16-bit data frame                                                                                                                                                                                                |
| Bit 10   | ORA    | 0x0         | rw   | Receive-only active<br>In two-wire unidirectional mode, when this bit is set, it indicates that Receive-only is active, but the transmit is not allowed.<br>0: Transmission and reception<br>1: Receive-only mode                                                                                                                                     |
| Bit 9    | SWCSEN | 0x0         | rw   | Software CS enable<br>When this bit is set, the CS pin level is determined by the SWCSIL bit. The status of I/O level on the CK pin is invalid.<br>0: Disabled<br>1: Enabled                                                                                                                                                                          |
| Bit 8    | SWCSIL | 0x0         | rw   | Software CS internal level<br>This bit is valid only when the SWCSEN is set. It determines the level on the CS pin.<br>In master mode, this bit must be set.<br>0: Low level<br>1: High level                                                                                                                                                         |
| Bit 7    | LTF    | 0x0         | rw   | LSB transmit first<br>This bit is used to select for MST transfer first or LSB transfer first.<br>0: MSB<br>1: LSB                                                                                                                                                                                                                                    |
| Bit 6    | SPIEN  | 0x0         | rw   | SPI enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                               |
| Bit 5: 3 | MDIV   | 0x0         | rw   | Master clock frequency division<br>In master mode, the peripheral clock divided by the prescaler is used as SPI clock. The MDIV[3: 0]:<br>0000: Divided by 2<br>0001: Divided by 4<br>0010: Divided by 8<br>0011: Divided by 16<br>0100: Divided by 32<br>0101: Divided by 64<br>0110: Divided by 128<br>0111: Divided by 256<br>1000: Divided by 512 |

|       |        |     |    |                                                                                                                      |
|-------|--------|-----|----|----------------------------------------------------------------------------------------------------------------------|
|       |        |     |    | 1001: Divided by 1024                                                                                                |
| Bit 2 | MSTEN  | 0x0 | rw | Master enable<br>0: Disabled (Slave)<br>1: Enabled (Master)                                                          |
| Bit 1 | CLKPOL | 0x0 | rw | Clock polarity<br>Indicates the polarity of clock output in idle state.<br>0: Low level<br>1: High level             |
| Bit 0 | CLKPHA | 0x0 | rw | Clock phase<br>0: Data capture starts from the first clock edge<br>1: Data capture starts from the second clock edge |

*Note: The SPI\_CTRL1 register must be 0 in I<sup>2</sup>S mode.*

### 13.4.2 SPI control register 2 (SPI\_CTRL2)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x00        | resd | Forced to 0 by hardware.                                                                                                                                                                                                                                                                         |
| Bit 9      | MDIV3EN  | 0x0         | rw   | Master clock frequency divided by 3 enable<br>0: Disabled<br>1: Enabled<br><br>Note: When this bit is set, the MDIV[3: 0] becomes invalid, and the SPI clock is forced to be PCLK/3.<br>When SPI/3 and PCLK/SYSCLK≠1, SPI clock does meet 50% duty cycle. For details on timings, see datasheet. |
| Bit 8      | MDIV[3]  | 0x0         | rw   | Master clock frequency division<br>Refer to the MDIV[2: 0] of the SPI_CTRL1 register.                                                                                                                                                                                                            |
| Bit 7      | TDBEIE   | 0x0         | rw   | Transmit data buffer empty interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                         |
| Bit 6      | RDBFIE   | 0x0         | rw   | Receive data buffer full interrupt enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                           |
| Bit 5      | ERRIE    | 0x0         | rw   | Error interrupt enable<br>This bit controls interrupt generation when errors occur (CCERR, MMERR, ROERR and TUERR)<br>0: Disabled<br>1: Enabled                                                                                                                                                  |
| Bit 4      | TIEN     | 0x0         | rw   | TI mode enable<br>0: TI mode disabled (Motorola mode)<br>1: TI mode enabled (TI mode)<br><br>Note: This mode is not used in I <sup>2</sup> S mode. It must be 0 in I <sup>2</sup> S mode.                                                                                                        |
| Bit 3      | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                                                                                                            |
| Bit 2      | HWCSEOE  | 0x0         | rw   | Hardware CS output enable<br>This bit is valid only in master mode. When this bit is set, the I/O output on the CS pin is low; when this bit is 0, the I/O input on the CS pin must be set high.<br>0: Disabled<br>1: Enabled                                                                    |
| Bit 1      | DMATEN   | 0x0         | rw   | DMA transmit enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                 |
| Bit 0      | DMAREN   | 0x0         | rw   | DMA receive enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                  |

### 13.4.3 SPI status register (SPI\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                          |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 9 | Reserved | 0x00        | resd | Forced to 0 by hardware                                                                                                                                                                                              |
|           |          |             |      | CS pulse abnormal setting flag<br>0: CS pulse flag normal<br>1: CS pulse flag is set abnormally                                                                                                                      |
| Bit 8     | CSPAS    | 0x0         | ro   | Note: This bit is used for TI slave mode. It is cleared by reading the STS register.                                                                                                                                 |
|           |          |             |      | Busy flag<br>0: SPI is not busy.<br>1: SPI is busy.                                                                                                                                                                  |
| Bit 7     | BF       | 0x0         | ro   | Receiver overflow error                                                                                                                                                                                              |
| Bit 6     | ROERR    | 0x0         | ro   | 0: No overflow error<br>1: Overflow error occurs.                                                                                                                                                                    |
|           |          |             |      | Master mode error                                                                                                                                                                                                    |
| Bit 5     | MMERR    | 0x0         | ro   | This bit is set by hardware and cleared by software (read/write access to the SPI_STS register, followed by write operation to the SPI_CTRL1 register)<br>0: No mode error<br>1: Mode error occurs.                  |
|           |          |             |      | CRC error<br>Set by hardware, and cleared by software.<br>0: No CRC error<br>1: CRC error occurs.                                                                                                                    |
| Bit 4     | CCERR    | 0x0         | rw0c | Transmitter underload error<br>Set by hardware, and cleared by software (read the SPI_STS register).<br>0: No underload error<br>1: Underload error occurs.<br>Note: This bit is only used in I <sup>2</sup> S mode. |
| Bit 3     | TUERR    | 0x0         | ro   | Audio channel state<br>This bit indicates the status of the current audio channel.<br>0: Left channel<br>1: Right channel<br>Note: This bit is only used in I <sup>2</sup> S mode.                                   |
| Bit 2     | ACS      | 0x0         | ro   | Transmit data buffer empty                                                                                                                                                                                           |
| Bit 1     | TDBE     | 0x1         | ro   | 0: Transmit data buffer is not empty.<br>1: Transmit data buffer is empty.                                                                                                                                           |
| Bit 0     | RDBF     | 0x0         | ro   | Receive data buffer full<br>0: Transmit data buffer is not full.<br>1: Transmit data buffer is full.                                                                                                                 |

### 13.4.4 SPI data register (SPI\_DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                            |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | DT   | 0x0000      | rw   | Data value<br>This register controls read and write operations. When the data bit is set as 8 bit, only the 8-bit LSB [7: 0] is valid. |

### 13.4.5 SPICRC register (SPI\_CPOLY) (Not used in I<sup>2</sup>S mode)

| Bit       | Name  | Reset value | Type | Description                                                                                                                         |
|-----------|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | CPOLY | 0x0007      | rw   | CRC polynomial<br>This register contains the polynomial used for CRC calculation.<br>Note: This register is valid only in SPI mode. |

### 13.4.6 SPIRxCRC register (SPI\_RCRC) (Not used in I<sup>2</sup>S mode)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | RCRC | 0x0000      | ro   | Receive CRC<br>When CRC calculation is enabled, this register contains the CRC value computed based on the received data.<br>This register is reset when the CCEN bit in the SPI_CTRL1 register is cleared.<br>When the data frame format is set to 8-bit data, only the 8-bit LSB ([7: 0]) are calculated based on CRC8 standard; when 16-bit data bit is selected, follow CRC16 standard.<br>Note: This register is only used in SPI mode. |

### 13.4.7 SPITxCRC register (SPI\_TCRC)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | TCRC | 0x0000      | ro   | Transmit CRC<br>When CRC calculation is enabled, this register contains the CRC value computed based on the transmitted data.<br>This register is reset when the CCEN bit in the SPI_CTRL1 register is cleared.<br>When the data frame format is set to 8-bit data, only the 8-bit LSB ([7: 0]) are calculated based on CRC8 standard; when 16-bit data bit is selected, follow CRC16 standard.<br>Note: This register is only used in SPI mode. |

### 13.4.8 SPI\_I2S register (SPI\_I2SCTRL)

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                         |
|------------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 12 | Reserved  | 0x0         | resd | Forced to 0 by hardware.                                                                                                                                            |
| Bit 11     | I2SMSEL   | 0x0         | rw   | I <sup>2</sup> S mode select<br>0: SPI mode<br>1: I <sup>2</sup> S mode                                                                                             |
| Bit 10     | I2SEN     | 0x0         | rw   | I <sup>2</sup> S enable<br>0: Disabled<br>1: Enabled                                                                                                                |
| Bit 9: 8   | OPERSEL   | 0x0         | rw   | I <sup>2</sup> S operation mode select<br>00: Slave transmission<br>01: Slave reception<br>10: Master transmission<br>11: Master reception                          |
| Bit 7      | PCMFSSEL  | 0x0         | rw   | PCM frame synchronization<br>This bit is valid only when the PCM standard is used.<br>0: Short frame synchronization<br>1: Long frame synchronization               |
| Bit 6      | Reserved  | 0x0         | resd | Kept at default value                                                                                                                                               |
| Bit 5: 4   | STDSEL    | 0x0         | rw   | I <sup>2</sup> S standard select<br>00: Philips standard<br>01: MSB-aligned standard (left-aligned)<br>10: LSB-aligned standard (right-aligned)<br>11: PCM standard |
| Bit 3      | I2SCLKPOL | 0x0         | rw   | I <sup>2</sup> S clock polarity                                                                                                                                     |

|          |        |     |    |                                                                                                                                                                                                        |
|----------|--------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |     |    | This bit indicates the clock polarity on the clock pin in idle state.<br>0: Low<br>1: High                                                                                                             |
| Bit 2: 1 | I2SDBN | 0x0 | rw | I <sup>2</sup> S data bit num<br>00: 16-bit data length<br>01: 24-bit data length<br>10: 32-bit data length<br>11: Not allowed.                                                                        |
| Bit 0    | I2SCBN | 0x0 | rw | I <sup>2</sup> S channel bit num<br>This bit can be configured only when the I <sup>2</sup> S is set to 16-bit data; otherwise, it is fixed to 32-bit by hardware.<br>0: 16-bit wide<br>1: 32-bit wide |

### 13.4.9 SPI\_I2S prescaler register (SPI\_I2SCLKP)

| Bit                    | Name      | Reset value | Type | Description                                                                                                              |
|------------------------|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 12             | Reserved  | 0x0         | resd | Forced 0 by hardware.                                                                                                    |
| Bit 9                  | I2SMCLKOE | 0x0         | rw   | I <sup>2</sup> S Master clock output enable<br>0: Disabled<br>1: Enabled                                                 |
| Bit 8                  | I2SODD    | 0x0         | rw   | Odd factor for I <sup>2</sup> S division<br>0: Actual divider factor =I2SDIV*2<br>1: Actual divider factor =(I2SDIV*2)+1 |
| Bit 11: 10<br>Bit 7: 0 | I2SDIV    | 0x02        | rw   | I <sup>2</sup> S division<br>It is not allowed to configure I2SDIV[9: 0]=0 or I2SDIV[9: 0]=1                             |

# 14 Full-duplexed I<sup>2</sup>S interface (I<sup>2</sup>SF)

## 14.1 I<sup>2</sup>SF interface introduction

I<sup>2</sup>SF audio interface is an extended version of I<sup>2</sup>S which supports full duplex mode. Its master clock sources can be from system clock, PLL input clock, HICK output clock or external input clock. A more accurate audio frequency can be achieved by configuring the master clock of I<sup>2</sup>SF.

## 14.2 I<sup>2</sup>SF functional overview

In addition to I<sup>2</sup>S functionalities described in Chapter 13, there are additional features available to I<sup>2</sup>SF which will be detailed in the following sections.

### 14.2.1 I<sup>2</sup>SF full duplex mode

I<sup>2</sup>SF full-duplex mode is enabled by setting the I2SF\_DUPEN bit in the I2SF\_I2SCTRL register. The I<sup>2</sup>SF can operate in master or slave mode through setting the OPERSEL[1] register. When the I<sup>2</sup>SF is configured in master transmit or slave transmit mode through the OPERSEL[1:0], SD represents input while SDEXT represent input; when the I<sup>2</sup>SF operates in master-receive/slave receive mode, SD is used as input, and the SDEXT as output.

Figure 14-1 I<sup>2</sup>SF full-duplex host transmit/slave transmit



Figure 14-2 I<sup>2</sup>SF full-duplex host transmit/slave receive



Figure 14-3 I<sup>2</sup>SF full-duplex host receive/slave transmitFigure 14-4 I<sup>2</sup>SF full-duplex host receive/slave receive**Full-duplex transfer in master mode (I2SFDUPEN=1 and OPERSEL[9]=1)**

- The transfer sequence begins when a data is written to the I2SF\_DT register (transmission buffer).
- The data is parallel loaded into the shift register during the first bit transmission, and then shifted out, serially to the SD/SDEXT pin.
- The data received on SDEXT/SD are serially moved to the shift register, and then serially loaded into the I2SF\_DT register.

**Full-duplex transfer in slave mode (I2SFDUPEN=1 and OPERSEL[9]=0)**

- The data transfer begins when the slave receives a clock signal. Then the data on the SDEXT/SD are serially loaded into the shift register. The data in the shift register is sent to the I2SF\_DT register each time a 16-bit data transfer is finished.
- At the same time, the data of the I2SF\_DT register (transmission buffer) are in parallel loaded into the shift register, and then sent to the SD/SDEXT pins serially. It should be noted that the to-be-sent data have been written to the I2SF\_DT register before the I<sup>2</sup>SF host starts transferring data.

## 14.2.2 I2SF master clock sources

There are four clock sources dedicated to I<sup>2</sup>SF controller, which is configured through the I2SF5CLKSEL[1: 0] register. The external input clock is input via IO. The HICK oscillator clock output can be configured as 8M or 48M through the HICKDIV bit in the CRM\_MISC1 register. The PLL is derived from PLLP.

Figure 14-5 I<sup>2</sup>S master clock sources

### 14.2.3 PCM mode

The I<sup>2</sup>SF has an additional I2SFPCMCKSEL register used to select rising edge or falling edge of the clock for sampling data in PCM long-frame or PCM short-frame format. See the figures below for communication timings.

Figure 14-6 Data sampling on falling edge in PCM mode



Figure 14-7 Data sampling on rising edge in PCM mode



## 14.2.4 Interrupts

Figure 14-8 I<sup>2</sup>SF interrupts



## 14.2.5 IO pin control

When full-duplex feature is enabled, the I<sup>2</sup>SF needs three pins to implement I<sup>2</sup>S communication. They are SD (data pin), WS (synchronization pin) and CK (communication clock pin). If there is a need to provide main clock for peripherals, a MCLK is required. When the full-duplex mode is enabled, it requires another pin SDEXT to implement bidirectional data transfer. In master mode, it is possible to select CLKIN\_IN as the external input interface of I<sup>2</sup>S master clock through the I2SF5CLKSEL[1:0] register.

- SD: Serial data (mapped on the MOSI pin). It serves as a bidirectional transceiver pin when I<sup>2</sup>S full-duplex mode is disabled. The direction of data transfer is dependent on registers when the I<sup>2</sup>S full-duplex mode is enabled.
- SDEXT: this pin is not available when I<sup>2</sup>S full-duplex mode is disabled. The direction of data transfer is dependent on registers when I<sup>2</sup>S full-duplex mode is enabled.  
When the OPERSEL[9:8] is configured as host transmit/slave transmit mode, SD is used as output and the SDEXT as input. When the OPERSEL[9:8] is configured as host receive/slave receive mode, SD is used as input, and SDEXT as output.
- WS: Word select (mapped on the CS pin) for data control signal output in master mode, and input in slave mode.
- CK: Communication clock (mapped on the SCK pin) as clock signal output in master mode, and input in slave mode.
- CLKIN\_IN: It is the I<sup>2</sup>S master clock external input interface in master mode, and not available in slave mode.
- MCLK: Master clock (mapped independently) is used to provide main clock for peripherals. The frequency of output clock signal is set to 256x Fs (audio sampling frequency).

## 14.2.6 Special notes on I<sup>2</sup>SF usage

- The clock of the APB2 should be greater than the one of I<sup>2</sup>SF.
- In slave mode, when an edge is detected at an unexpected location, the CS pulse error flag is set by hardware, and it is cleared by software reading the register.

## 14.3 I<sup>2</sup>SF registers

These peripheral registers must be accessed by words (32 bits).

Table 14-1 I<sup>2</sup>SF5 register map and reset value

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| I2SF_CTRL2   | 0x04   | 0x0000      |
| I2SF_STS     | 0x08   | 0x0002      |
| I2SF_DT      | 0x0C   | 0x0000      |
| I2SF_I2SCTRL | 0x1C   | 0x0000      |
| I2SF_I2SCLKP | 0x20   | 0x0002      |
| I2SF_MISC1   | 0x30   | 0x0000      |

### 14.3.1 I<sup>2</sup>SF control register 2 (I2SF\_CTRL2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                     |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 8 | Reserved | 0x00        | resd | Forced to 0 by hardware.                                                                                                                        |
| Bit 7     | TDBEIE   | 0x0         | rw   | Transmit data buffer empty interrupt enable<br>0: Disabled<br>1: Enabled                                                                        |
| Bit 6     | RDBFIE   | 0x0         | rw   | Receive data buffer full interrupt enable<br>0: Disabled<br>1: Enabled                                                                          |
| Bit 5     | ERRIE    | 0x0         | rw   | Error interrupt enable<br>This bit controls interrupt generation when errors occur (CCERR, MMERR, ROERR and TUERR)<br>0: Disabled<br>1: Enabled |
| Bit 4: 2  | Reserved | 0x0         | resd | Kept at default value                                                                                                                           |
| Bit 1     | DMATEN   | 0x0         | rw   | DMA transmit enable<br>0: Disabled<br>1: Enabled                                                                                                |
| Bit 0     | DMAREN   | 0x0         | rw   | DMA receive enable<br>0: Disabled<br>1: Enabled                                                                                                 |

### 14.3.2 I<sup>2</sup>SF status register (I2SF\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                             |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 9 | Reserved | 0x00        | resd | Forced to 0 by hardware                                                                                                                                                                 |
| Bit 8     | CSPAS    | 0x0         | ro   | CS pulse abnormal setting flag<br>0: CS pulse flag normal<br>1: CS pulse flag is set abnormally<br>Note: This bit is used for TI slave mode. It is cleared by reading the STS register. |
| Bit 7     | BF       | 0x0         | ro   | Busy flag<br>0: SPI is not busy.<br>1: SPI is busy.                                                                                                                                     |
| Bit 6     | ROERR    | 0x0         | ro   | Receiver overflow error<br>0: No overflow error<br>1: Overflow error occurs.                                                                                                            |
| Bit 5: 4  | Reserved | 0x0         | resd | Forced to 0 by hardware                                                                                                                                                                 |
| Bit 3     | TUERR    | 0x0         | ro   | Transmitter underload error<br>Set by hardware, and cleared by software (read the                                                                                                       |

|       |      |     |    |                                                                                                                                                                                    |
|-------|------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |    | SPI_STS register).<br>0: No underrun error<br>1: Underrun error occurs.<br>Note: This bit is only used in I <sup>2</sup> S mode.                                                   |
| Bit 2 | ACS  | 0x0 | ro | Audio channel state<br>This bit indicates the status of the current audio channel.<br>0: Left channel<br>1: Right channel<br>Note: This bit is only used in I <sup>2</sup> S mode. |
| Bit 1 | TDBE | 0x1 | ro | Transmit data buffer empty<br>0: Transmit data buffer is not empty.<br>1: Transmit data buffer is empty.                                                                           |
| Bit 0 | RDBF | 0x0 | ro | Receive data buffer full<br>0: Transmit data buffer is not full.<br>1: Transmit data buffer is full.                                                                               |

### 14.3.3 I<sup>2</sup>SF data register (I2SF\_DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                            |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | DT   | 0x0000      | rw   | Data value<br>This register controls read and write operations. When the data bit is set as 8 bit, only the 8-bit LSB [7: 0] is valid. |

### 14.3.4 I<sup>2</sup>S configuration register (I2SF\_I2SCTRL)

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                         |
|------------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 12 | Reserved  | 0x0         | resd | Forced to 0 by hardware.                                                                                                                                            |
| Bit 13     | I2SFDUPEN | 0x0         | rw   | I <sup>2</sup> S full duplex enable<br>0: I <sup>2</sup> S full duplex disabled<br>1: I <sup>2</sup> S full duplex enabled                                          |
| Bit 12:11  | Reserved  | 0x0         | resd | Forced to 0 by hardware.                                                                                                                                            |
| Bit 10     | I2SEN     | 0x0         | rw   | I <sup>2</sup> S enable<br>0: Disabled<br>1: Enabled                                                                                                                |
| Bit 9: 8   | OPERSEL   | 0x0         | rw   | I <sup>2</sup> S operation mode select<br>00: Slave transmission<br>01: Slave reception<br>10: Master transmission<br>11: Master reception                          |
| Bit 7      | PCMFSSEL  | 0x0         | rw   | PCM frame synchronization<br>This bit is valid only when the PCM standard is used.<br>0: Short frame synchronization<br>1: Long frame synchronization               |
| Bit 6      | Reserved  | 0x0         | resd | Kept at default value                                                                                                                                               |
| Bit 5: 4   | STDSEL    | 0x0         | rw   | I <sup>2</sup> S standard select<br>00: Philips standard<br>01: MSB-aligned standard (left-aligned)<br>10: LSB-aligned standard (right-aligned)<br>11: PCM standard |
| Bit 3      | I2SCLKPOL | 0x0         | rw   | I <sup>2</sup> S clock polarity<br>This bit indicates the clock polarity on the clock pin in idle state.<br>0: Low<br>1: High                                       |
| Bit 2: 1   | I2SDBN    | 0x0         | rw   | I <sup>2</sup> S data bit num<br>00: 16-bit data length<br>01: 24-bit data length<br>10: 32-bit data length<br>11: Not allowed.                                     |

|       |        |     |    |                                                                                                                                                                                                        |
|-------|--------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 | I2SCBN | 0x0 | rw | I <sup>2</sup> S channel bit num<br>This bit can be configured only when the I <sup>2</sup> S is set to 16-bit data; otherwise, it is fixed to 32-bit by hardware.<br>0: 16-bit wide<br>1: 32-bit wide |
|-------|--------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 14.3.5 I<sup>2</sup>SF prescaler register (I2SF\_I2SCLKP)

| Bit        | Name      | Reset value | Type | Description                                                                                                              |
|------------|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 12 | Reserved  | 0x0         | resd | Forced 0 by hardware.                                                                                                    |
| Bit 9      | I2SMCLKOE | 0x0         | rw   | I <sup>2</sup> S Master clock output enable<br>0: Disabled<br>1: Enabled                                                 |
| Bit 8      | I2SODD    | 0x0         | rw   | Odd factor for I <sup>2</sup> S division<br>0: Actual divider factor =I2SDIV*2<br>1: Actual divider factor =(I2SDIV*2)+1 |
| Bit 11: 10 | I2SDIV    | 0x02        | rw   | I <sup>2</sup> S division<br>It is not allowed to configure I2SDIV[9: 0]=0 or I2SDIV[9: 0]=1                             |
| Bit 7: 0   |           |             |      |                                                                                                                          |

### 14.3.6 I<sup>2</sup>SF additional register (I2SF\_MISC1)

| Bit       | Name         | Reset value | Type | Description                                                                 |
|-----------|--------------|-------------|------|-----------------------------------------------------------------------------|
| Bit 15: 1 | Reserved     | 0x0         | resd | Forced 0 by hardware.                                                       |
| Bit 0     | I2SFPCMCKSEL | 0x02        | rw   | I <sup>2</sup> S PCM clock edge select<br>0: Falling edge<br>1: Rising edge |

## 15 Timer

The AT32F402/405 series timers include basic timers, general-purpose timers, and advanced timers. Please refer to [Section 15.1 ~ Section 15.5](#) for detailed function modes. All functions of different timers are shown in the following tables.

Table 15-1 TMR functional comparison

| Timer type             | Timer | Counter bit | Count mode            | Repetition | Prescaler | DMA requests | Capture/compare channel | PWM input mode | ETR input | Brake input |
|------------------------|-------|-------------|-----------------------|------------|-----------|--------------|-------------------------|----------------|-----------|-------------|
| Advanced-control timer | TMR1  | 16          | Up<br>Down<br>Up/Down | 16-bit     | 1~65535   | O            | 4                       | O              | O         | O           |
| General-purpose timer  | TMR2  | 16/32       | Up<br>Down<br>Up/Down | X          | 1~65535   | O            | 4                       | O              | O         | X           |
|                        | TMR3  | 16          | Up<br>Down<br>Up/Down | X          | 1~65535   | O            | 4                       | O              | O         | X           |
|                        | TMR4  |             | Up                    |            |           |              |                         |                |           |             |
|                        | TMR9  | 16          | Down<br>Up/Down       | 8-bit      | 1~65535   | O            | 2                       | O              | X         | O           |
|                        | TMR10 |             | Up                    |            |           |              |                         |                |           |             |
|                        | TMR11 | 16          | Down<br>Up/Down       | 8-bit      | 1~65535   | O            | 1                       | X              | X         | O           |
|                        | TMR13 |             |                       |            |           |              |                         |                |           |             |
|                        | TMR14 |             |                       |            |           |              |                         |                |           |             |
| Basic timer            | TMR6  | 16          | Up                    | X          | 1~65535   | O            | X                       | X              | X         | X           |
|                        | TMR7  |             |                       |            |           |              |                         |                |           |             |

| Timer type             | Timer | Counter bit | Count mode            | PWM output | Single pulse output | Complementary output | Dead-time | Encoder interface connection | Interfacing with hall sensors | Linkage peripheral            |
|------------------------|-------|-------------|-----------------------|------------|---------------------|----------------------|-----------|------------------------------|-------------------------------|-------------------------------|
| Advanced-control timer | TMR1  | 16          | Up<br>Down<br>Up/Down | O          | O                   | O                    | O         | O                            | O                             | Timer synchronization/ADC     |
| General-purpose time   | TMR2  | 16/32       | Up<br>Down<br>Up/Down | O          | O                   | X                    | X         | O                            | O                             | Timer synchronization/ADC     |
|                        | TMR3  | 16          | Up<br>Down<br>Up/Down | O          | O                   | X                    | X         | O                            | O                             | Timer synchronization/ADC     |
|                        | TMR4  |             |                       |            |                     |                      |           |                              |                               |                               |
|                        | TMR9  | 16          | Up<br>Down<br>Up/Down | O          | O                   | O                    | O         | O                            | X                             | Timer synchronization/<br>ADC |
|                        | TMR10 |             |                       |            |                     |                      |           |                              |                               |                               |
|                        | TMR11 | 16          | Up<br>Down            | O          | O                   | O                    | O         | X                            | X                             | Timer synchronization         |
|                        | TMR13 |             |                       |            |                     |                      |           |                              |                               |                               |
|                        | TMR14 |             |                       |            |                     |                      |           |                              |                               |                               |
| Basic timer            | TMR6  | 16          | Up                    | X          | X                   | X                    | X         | X                            | X                             | ADC                           |
|                        | TMR7  |             |                       |            |                     |                      |           |                              |                               |                               |

## 15.1 Basic timers (TMR6 and TMR7)

### 15.1.1 TMR6 and TMR7 introduction

Basic timers (TMR6 and TMR7) include a 16-bit upcounter with corresponding control logic, without being connected to external I/Os. They can be used for basic timing function.

### 15.1.2 TMR6 and TMR7 main features

- 16-bit auto reload upcounter
- 16-bit prescaler used to divide the TMR\_CLK clock frequency by any factor between 1 and 65536

Figure 15-1 Basic timer block diagram



### 15.1.3 TMR6 and TMR7 functional overview

#### 15.1.3.1 Counting clock

The counter clock of TMR6 and TMR7 is provided by the internal clock source (CK\_INT) divided by prescaler. When TMR's APB clock prescaler factor is 1, the CK\_INT frequency is equal to that of the APB; otherwise, it doubles the APB clock frequency.

Figure 15-2 Internal counting clock example



#### 15.1.3.2 Counting mode

The basic timer only supports upcounting mode. It has an internal 16-bit counter.

The TMRx\_PR register is used to set counting period of the counter. The value in the TMRx\_PR is immediately moved to the shadow register by default. When the periodic buffer is enabled (PRBEN=1), the value in the TMRx\_PR register is transferred to the shadow register only at an overflow event.

TMRx\_DIV register is used to define the counting frequency of the counter. The counter counts once every DIV[15:0]+1 clock cycle. The value of the TMRx\_DIV register is transferred into the shadow register upon an overflow event.

Reading the TMRx\_CNT register returns the current counter value. Writing the TMRx\_CNT register will update the current counter value.

An overflow event is enabled by default. It can be disabled by setting OVFEN=1 in the TMRx\_CTRL1 register. The OVFS bit in the TMRx\_CTRL1 register is used to select the source of an overflow event, which is, by default, counter overflow or underflow, setting OVFSWTR, reset signal generated by slave mode timer controller in reset mode. Once the OVFS is set, an overflow event is generated only when overflow or underflow occurs.

Setting the TMREN bit (TMREN=1) enables the timer to start counting. Base on synchronization logic, however, the actual counter enable signal TMR\_EN is set 1 clock cycle after the TMREN is set.

Figure 15-3 Basic structure of a counter



### Upcounting mode

Upcounting mode is enabled by setting CMSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register.

In upcounting mode, the counter counts from 0 to the value programmed in the TMRx\_PR register, then restarts from 0 and generates a counter overflow event with setting OVFIF=1 at the same time. If the overflow event is disabled, the counter is no longer reloaded with a prescaler value and a periodic value when a counter overflow event occurs; otherwise, the counter is updated with prescaler and periodic values at an overflow event.

Figure 15-4 Overflow event when PRBEN=0



Figure 15-5 Overflow event when PRBEN=1



Figure 15-6 Counting timing diagram when the prescaler division is 3



### 15.1.3.3 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the TMRx counter stops counting when the TMRx\_PAUSE bit is set to 1 in the DEBUG module.

### 15.1.4 TMR6 and TMR7 registers

These peripheral registers have to be accessed by words (32 bits).

Table 15-2 TMR6 and TMR7 register table and reset value

| Register   | Offset | Reset value |
|------------|--------|-------------|
| TMRx_CTRL1 | 0x00   | 0x0000 0000 |
| TMRx_CTRL2 | 0x04   | 0x0000 0000 |
| TMRx_IDEN  | 0x0C   | 0x0000 0000 |
| TMRxISTS   | 0x10   | 0x0000 0000 |
| TMRx_SWEVT | 0x14   | 0x0000 0000 |
| TMRx_CVAL  | 0x24   | 0x0000 0000 |
| TMRx_DIV   | 0x28   | 0x0000 0000 |
| TMRx_PR    | 0x2C   | 0x0000 FFFF |

#### 15.1.4.1 TMR6 and TMR7 control register 1 (TMRx\_CTRL1)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 7     | PRBEN    | 0x0         | rw   | Period buffer enable<br>0: Period buffer is disabled.<br>1: Period buffer is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 6: 4  | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 3     | OCMEN    | 0x0         | rw   | One cycle mode enable<br>This bit is used to select whether to stop the counter at overflow event.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 2     | OVFS     | 0x0         | rw   | Overflow event source<br>This bit is used to select overflow event or DMA request sources.<br>0: Counter overflow, overflow event generated by setting the OVFSWTR bit or from the slave timer controller<br>1: Only counter overflow generates an overflow event.                                                                                                                                                                                                                                                                           |
| Bit 1     | OVFEN    | 0x0         | rw   | Overflow event enable<br>This bit is used to enable or disable OEV event generation.<br>0: OEV event is enabled. An overflow event is generated by any of the following events:<br>- Counter overflow<br>- Setting the OVFSWTR bit to 1<br>- Overflow event generated from the slave timer controller<br>1: OEV event is disabled.<br>If the OVFSWTR bit is set to 1, or if a software reset is generated from the slave mode controller, the counter and the prescaler are reinitialized.<br>Note: This bit is set and cleared by software. |
| Bit 0     | TMREN    | 0x0         | rw   | TMR enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

### 15.1.4.2 TMR6 and TMR7 control register 2 (TMRx\_CTRL2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                  |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x000 0000  | resd | Kept at default value.                                                                                                                                                       |
| Bit 6: 4  | PTOS     | 0x0         | rw   | Master TMR output selection<br>This field is used to select the signals in master mode to be sent to slave timers.<br>000: Software overflow<br>001: Enable<br>010: Overflow |
| Bit 3: 0  | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                       |

### 15.1.4.3 TMR6 and TMR7 DMA/interrupt enable register (TMRx\_IDEN)

| Bit       | Name     | Reset value | Type | Description                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------|
| Bit 31: 9 | Reserved | 0x00 0000   | resd | Kept at default value.                                         |
| Bit 8     | OVFDEN   | 0x0         | rw   | Overflow event DMA request enable<br>0: Disabled<br>1: Enabled |
| Bit 7: 1  | Reserved | 0x00        | resd | Kept at default value.                                         |
| Bit 0     | OVFIEN   | 0x0         | rw   | Overflow interrupt enable<br>0: Disabled<br>1: Enabled         |

### 15.1.4.4 TMR6 and TMR7 interrupt status register (TMRxISTS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x0000 0000 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 0     | OVFIF    | 0x0         | rw0c | Overflow interrupt flag<br>This bit is set by hardware at an overflow event. It is cleared by software.<br>0: No overflow event occurred.<br>1: Overflow event occurred, and if OVFEN=0, and OVFS=0 in the TMRx_CTRL1 register:<br>- An overflow event occurred when OVFSWTR=1 in the TMRx_SWEVT register<br>- An overflow event occurred when the counter value (CVAL) is reinitialized by a trigger event. |

### 15.1.4.5 TMR6 and TMR7 software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                      |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x0000 0000 | resd | Kept at default value.                                                                                                                           |
| Bit 0     | OVFSWTR  | 0x0         | rw0c | Overflow event triggered by software<br>An overflow event is triggered by software.<br>0: No effect<br>1: Generate an overflow event by software |

### 15.1.4.6 TMR6 and TMR7 counter value (TMRx\_CVAL)

| Bit        | Name     | Reset value | Type | Description            |
|------------|----------|-------------|------|------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value. |
| Bit 15: 0  | CVAL     | 0x0000      | rw   | Counter value          |

### 15.1.4.7 TMR6 and TMR7 division (TMRx\_DIV)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                             |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                  |
| Bit 15: 0  | DIV      | 0x0000      | rw   | Divider value<br>The counter clock frequency $f_{CK\_CNT} = f_{TMR\_CLK} / (\text{DIV}[15:0]+1)$ .<br>At each overflow event, DIV value is written to the DIV register. |

### 15.1.4.8 TMR6 and TMR7 period register (TMRx\_PR)

| Bit        | Name     | Reset value | Type | Description                                                                                              |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                   |
| Bit 15: 0  | PR       | 0xFFFF      | rw   | This indicates the period value of the TMRx counter. The timer stops working when the period value is 0. |

## 15.2 General-purpose timers (TMR2 to TMR4)

### 15.2.1 TMR2 to TMR4 introduction

The general-purpose timers (TMR2 to TMR4) consist of a 16-bit counter supporting up, down, up/down (TMR2 can be extended to 32 bits) counting modes. They have four capture/compare registers, and four independent channels for input capture and programmable PWM output.

### 15.2.2 TMR2 to TMR4 main features

- Counter clock sources: internal clock, external clock and internal trigger input
- 16-bit up, down, up/down and encoder mode counter
- 4 independent channels for input capture, output compare, PWM generation and one-pulse mode output
- Synchronization control between master and slave timers
- Interrupt/DMA generation at overflow event, trigger event and channel event
- Support TMR burst DMA transfer

Figure 15-7 General-purpose timer block diagram



### 15.2.3 TMR2 to TMR4 functional overview

#### 15.2.3.1 Counting clock

The counter clock of TMR2 to TMR4 can be provided by the internal clock (CK\_INT), external clock (external clock mode A and B) and internal trigger input (ISx).

Figure 15-8 Counting clock



### Internal clock (CK\_INT)

By default, the CK\_INT, which is divided by a prescaler, is used to drive the counter to count. When TMR's APB clock prescaler factor is 1, the CK\_INT frequency is equal to APB; otherwise, it doubles the APB clock frequency.

Follow the procedures below:

- Select a counting mode by setting the TWCMSEL[1:0] in TMRx\_CTRL1 register. If a unidirectional aligned counting mode is selected, it is necessary to select a counting direction through the OWCDIR bit in TMRx\_CTRL1 register.
- Set counting frequency through TMRx\_DIV register
- Set counting cycles through TMRx\_PR register
- Enable the counter by setting the TMREN bit in the TMRx\_CTRL1 register

Figure 15-9 Control circuit with CK\_INT, TMRx\_DIV=0x0 and TMRx\_PR=0x16



### External clock (TRGIN/EXT)

The counter clock can be provided by two external clock sources, namely, TRGIN and EXT signals.

**SMSEL=3'b111:** External clock mode A is selected. Select an external clock source TRGIN signal by setting the STIS[2: 0] bit to drive the counter to start counting.

The external clock sources include:

C1INC (STIS=3'b100, channel 1 rising edge and falling edge)

C1IFP1 (STIS=3'b101, channel 1 signal after filtering and polarity selection)

C2IFP2 (STIS=3'b110, channel 2 signal after filtering and polarity selection)

EXT (STIS=3'b111, external input signal after polarity selection, frequency division and filtering).

**ECMBEN=1:** External clock mode B is selected. The counter is driven by external input that has gone through polarity selection, frequency division and filtering. The external clock mode B is equivalent to the external clock mode A which selects EXT signal as an external force TRGIN.

#### To use external clock mode A, follow the steps below:

- Set external source TRGIN parameters

If the TMRx\_CH1 is used as a source of TRGIN, it is necessary to configure channel 1 input filter (C1DF[3:0] in TMRx\_CM1 register) and channel 1 input polarity (C1P/C1CP in TMRx\_CCTRL register);

If the TMRx\_CH2 is used as source of TRGIN, it is necessary to configure channel 2 input filter (C2DF[3:0] in TMRx\_CM1 register) and channel 2 input polarity (C2P/C2CP in TMRx\_CCTRL register);

If the TMRx\_EXT is used as a source of TRGIN, it is necessary to configure the external signal polarity (ESP in TMRx\_STCTRL register), external signal frequency division (ESDIV[1:0] in TMRx\_STCTRL) and external signal filter (ESF[3:0] in TMRx\_STCTRL register).

- Set TRGIN signal source using the STIS[1:0] bit in TMRx\_STCTRL register
- Enable external clock mode A by setting SMSEL=3'b111 in TMRx\_STCTR register
- Set counting frequency through the DIV[15:0] in TMRx\_DIV register
- Set counting period through the PR[15:0] in TMRx\_PR register
- Enable counter through the TMREN bit in TMRx\_CTRL1 register

**To use external clock mode B, follow the steps below:**

- Set external signal polarity through the ESP bit in TMRx\_STCTRL register
- Set external signal frequency division through the ESDIV[1:0] bit in TMRx\_STCTRL register
- Set external signal filter through the ESF[3:0] bit in TMRx\_STCTRL register
- Enable external clock mode B through the ECMBEN bit in TMRx\_STCTR register
- Set counting frequency through the DIV[15:0] bit in TMRx\_DIV register
- Set counting period through the PR[15:0] bit in TMRx\_PR register
- Enable counter through the TMREN in TMRx\_CTRL1 register

Figure 15-10 Block diagram of external clock mode A



*Note: The delay between the signal on the input side and the actual clock of the counter is due to the synchronization circuit.*

Figure 15-11 Counting in external clock mode A, PR=0x32 and DIV=0x0



Figure 15-12 Block diagram of external clock mode B



*Note: The delay between the EXT signal on the input side and the actual clock of the counter is due to the synchronization circuit.*

Figure 15-13 Counting in external clock mode B, PR=0x32 and DIV=0x0

**Internal trigger input (ISx)**

Timer synchronization allows interconnection between several timers. The TMR\_CLK of one timer can be provided by the TRGOOUT signal from another timer. The internal trigger signal is selected by setting the STIS[2: 0] bit to enable counting.

TMR2 to TMR4 consist of a 16-bit prescaler, which is used to generate the CK\_CNT that enables the counter to count. The frequency division relationship between the CK\_CNT and TMR\_CLK can be adjusted by setting the value of the TMRx\_DIV register. The prescaler value can be modified at any time, but the new prescaler value is taken into account when the next overflow event occurs.

**Below is the configuration procedure for internal trigger input:**

- Set counting cycles through TMRx\_PR register
- Set counting frequency through TMRx\_DIV register
- Set counting modes through the TWCMSEL[1:0] in TMRx\_CTRL1 register
- Select internal trigger by setting STIS[2:0]=3'b000~3'b011 in TMRx\_STCTRL register
- Select external clock mode A by setting SMSEL[2:0]=3'b111 in TMRx\_STCTRL register
- Enable TMRx to start counting through the TMREN in TMRx\_CTRL1 register

Table 15-3 TMRx internal trigger connection

| Slave controller | IS0<br>(STIS = 000) | IS1<br>(STIS = 001) | IS2<br>(STIS = 010) | IS3<br>(STIS = 011) |
|------------------|---------------------|---------------------|---------------------|---------------------|
| TMR2             | TMR1                | TMR9                | TMR3                | OTGFS_SOF           |
| TMR3             | TMR1                | TMR2                | TMR9                | TMR4                |
| TMR4             | TMR1                | TMR2                | TMR3                | TMR9                |

*Note 1: If there is no corresponding timer in a device, the corresponding trigger signal ISx is not present.*

Figure 15-14 Counter timing with prescaler value change from 0 to 3



### 15.2.3.2 Counting mode

The timers (TMR2 to TMR4) support several counting modes to meet different application scenarios. They have an internal 16-bit up, down, up/down counter. TMR2/5 can be extended to 32 bits by setting the PMEN bit to 1.

The TMRx\_PR register is used to set counting period of the counter. The value in the TMRx\_PR is immediately moved to the shadow register by default. When the periodic buffer is enabled (PRBEN=1), the value in the TMRx\_PR register is transferred to the shadow register only at an overflow event.

TMRx\_DIV register is used to define the counter frequency of the counter. The counter counts once every DIV[15:0]+1 clock cycle. The value of the TMRx\_DIV register is transferred into the shadow register at each overflow event.

Reading the TMRx\_CNT register returns the current counter value. Writing the TMRx\_CNT register will update the current counter value.

An overflow event is enabled by default. It can be disabled by setting OVFEN=1 in the TMRx\_CTRL1 register. The OVFS bit in the TMRx\_CTRL1 register is used to select the source of an overflow event, which is, by default, counter overflow or underflow, setting OVFSWTR, reset signal generated by slave mode timer controller in reset mode. Once the OVFS is set, an overflow event is generated only when overflow or underflow occurs.

Setting the TMREN bit (TMREN=1) enables the timer to start counting. Base on synchronization logic, however, the actual enable signal TMR\_EN is set 1 clock cycle after the TMREN is set.

Figure 15-15 Basic structure of a counter



#### Upcounting mode

This mode is enabled by setting CMSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register.

In upcounting mode, the counter counts from 0 to the value programmed in the TMRx\_PR register, restarts from 0, and generates a counter overflow event, with setting OVIF=1. If the overflow event is disabled, the register is no longer reloaded with the prescaler and periodic value after counter overflow occurs; otherwise, the prescaler and periodic value will be updated at an overflow event.

Figure 15-16 Overflow event when PRBEN=0



Figure 15-17 Overflow event when PRBEN=1



### Downcounting mode

This mode is enabled by setting CMSEL[1:0]=2'b00 and OWCDIR=1'b1 in the TMRx\_CTRL1 register. In downcounting mode, the counter counts from the value programmed in the TMRx\_PR register down to 0, and restarts from the value programmed, and generates a counter underflow event.

Figure 15-18 Counter timing diagram with internal clock divided by 3



### Up/down counting mode (center-aligned mode)

This mode is selected by setting CMSEL[1:0]≠2'b00 in the TMRx\_CTRL1 register.

In up/down counting mode, the counter counts up/down alternatively. When the counter counts from the value programmed in the TMRx\_PR register down to 1, an underflow event is generated, and then restarts counting from 0; when the counter counts from 0 to the value of the TMRx\_PR register -1, an overflow event is generated, and then restarts counting from the value of the TMRx\_PR register. The OWCDIR bit indicates the current counting direction.

The TWCMSEL[1:0] bit in the TMRx\_CTRL1 register is used to select the condition under which the CxIF flag is set in two-way counting mode. In other words, when TWCMSEL[1:0]=2'b01 (counting mode 1) is selected, the CxIF flag is set only when the counter counts down; when TWCMSEL[1:0]=2'b10 (counting mode 2) is selected, the CxIF flag is set only when the counter counts up; when TWCMSEL[1:0]=2'b11 (counting mode 3) is selected, the CxIF flag is set when the counter counts up and down.

*Note: The OWCDIR is read-only in up/down counting mode.*

Figure 15-19 Counter timing diagram with internal clock divided by 0 and TMRx\_PR=0x32



### Encoder interface mode

In this mode, the two input signals, TMRx\_CH1 and TMRx\_CH2, are required. Depending on the level on one input signal, the counter counts up or down on the edge of the other input signal. The OWCDIR bit indicates the direction of the counter, as shown in the table below:

Figure 15-20 Encoder mode structure



**Encoder mode A:** SMSEL=3'b001. The counter counts on the selected C1IFP1 edge (rising and falling edges), and the counting direction is dependent on the edge direction of C1IFP1 and the level of C2IFP2.

**Encoder mode B:** SMSEL=3'b010. The counter counts on the selected C2IFP2 edge (rising and falling edges), and the counting direction is dependent on the edge direction of C2IFP2 and the level of C1IFP1.

**Encoder mode C:** SMSEL=3'b011. The counter counts on both C1IFP1 and C2IFP2 edges (rising and falling edges). The counting direction is dependent on the C1IFP1 edge direction and C2IFP2 level, and C2IFP2 edge direction and C1IFP1 level.

To use encoder mode, follow the procedures below:

- Set channel 1 input signal filtering through the C1DF[3:0] bit in the TMRx\_CM1 register;
- Set channel 1 input signal active level through the C1P bit in the TMRx\_CCTRL register
- Set channel 2 input signal filtering through the C2DF[3:0] bit in the TMRx\_CM1 register;
- Set channel 2 input signal active level through the C2P bit in the TMRx\_CCTRL register
- Set channel 1 as input mode through the C1C[1:0] bit in the TMRx\_CM1 register;
- Set channel 2 as input mode through the C2C[1:0] bit in the TMRx\_CM1 register
- Select encoder mode A (SMSEL=3'b001), encoder mode B (SMSEL=3'b010), or encoder mode C (SMSEL=3'b011) by setting the SMSEL[2:0] bit in the TMRx\_STCTRL register
- Set counting cycles through the PR[15:0] bit in the TMRx\_PR register
- Set counting frequency through the DIV[15:0] bit in the TMRx\_DIV register
- Configure the corresponding IOs of TMRx\_CH1 and TMRx\_CH2 as multiplexed mode
- Enable counter through the TMREN bit in the TMRx\_CTRL1 register

Table 15-4 Counting direction versus encoder signals

| Active edge                        | Level on opposite signal<br>(C1IFP1 to C2IFP2, C2IFP2<br>to C1IFP1) | C1IFP1 signal |          | C2IFP2 signal |          |
|------------------------------------|---------------------------------------------------------------------|---------------|----------|---------------|----------|
|                                    |                                                                     | Rising        | Falling  | Rising        | Falling  |
| Count on C1IFP1 only               | High                                                                | Down          | Up       | No count      | No count |
|                                    | Low                                                                 | Up            | Down     | No count      | No count |
| Count on C2IFP2 only               | High                                                                | No count      | No count | Up            | Down     |
|                                    | Low                                                                 | No count      | No count | Down          | Up       |
| Count on both C1IFP1<br>and C2IFP2 | High                                                                | Down          | Up       | Up            | Down     |
|                                    | Low                                                                 | Up            | Down     | Down          | Up       |

Figure 15-21 Example of counter behavior in encoder interface mode (encoder mode C)



### 15.2.3.3 TMR input function

Each of timers (TMR2 to TMR4) has four independent channels, with each channel being configured as input or output. As input, each channel input signal is processed as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. The C1INSE bit is used to select the source of C1IRAW from TMRx\_CH1, or XOR-ed TMRx\_CH1, TMRx\_CH2 and TMRx\_CH3. The sources of C2IRAW, C3IRAW and C4IRAW are TMRx\_CH2, TMRx\_CH3 and TMRx\_CH4 respectively.
- CxIRAW inputs digital filter and outputs filtered CxIF signal. The digital filter uses the CxDI bit to program sampling frequency and sampling times.
- CxIF goes through edge detector, and generates CxIFPx signal after edge selection. The edge selection depends on both CxP and CxCp bits. It is possible to select input rising edge, falling edge or both edges.
- CxIFPx goes through capture signal selector, and generates the CxIN signal after capture signal selection. The capture signal selection is defined by CxC bits. It is possible to select CxIFPx, CyIFPx or STCI as CxIN source. Of those, CyIFPx ( $x \neq y$ ) is the CyIFPy signal that is from Y channel and processed by channel-x edge detector (for example, C1IFP2 is the C1IFP1 signal that is from channel 1 and passes through channel 2 edge detector). The STCI comes from slave timer controller, and its source is selected by STIS bit.
- CxIN goes through input divider and generates the CxIPS signal. The divider factor can be defined as No division, /2, /4 or /8, by the CxIDIV bit.

Figure 15-22 Input/output channel 1 main circuit



Figure 15-23 Channel 1 input stage



### Input mode

In input mode, the TMRx\_CxDT register latches the current counter values after the selected trigger signal is detected, and the capture compare interrupt flag bit (CxIF) is set to 1. An interrupt or a DMA request will be generated if the CxIEN and CxDEN bits are enabled. If the selected trigger signal is detected when the CxIF is set to 1, a capture overflow event is generated, and the previous counter value will be overwritten by the current counter value, with setting CxRF to 1.

To capture the rising edge of C1IN input, follow the procedure below

- Set C1C=01 in the TMRx\_CM1 register to select the C1IN as channel 1 input
- Set C1IN signal filter bandwidth (CxDF[3: 0])
- Set the active edge of C1IN channel by writing C1P=0 (rising edge) in the TMRx\_CCTRL register
- Program C1IN signal capture frequency divider (C1DIV[1: 0]);
- Enable channel 1 input capture (C1EN=1)
- If needed, enable the relevant interrupt or DMA request by setting the C1IEN bit in the TMRx\_IDEN register or the C1DEN bit in the TMRx\_IDEN register

### Timer Input XOR function

The 3 timer input pins (TMRx\_CH1, TMRx\_CH2 and TMRx\_CH3) are connected to the channel 1 through an XOR gate. This function is selected by setting the C1INSE in the TMRx\_CTRL2 register.

The XOR gate can be used to connect Hall sensors. For example, connect the three XORED inputs to the three Hall sensors respectively so as to calculate the position and speed of the rotation by analyzing three Hall sensor signals.

### PWM input

PWM input mode is applied to channel 1 and 2. To use this mode, both C1IN and C2IN have to be mapped to the same TMRx\_CHx, and the CxIFPx of either channel 1 or channel 2 must be configured as trigger input and slave timer controller is configured in reset mode.

The PWM input mode can be used to measure the period and duty cycle of the PWM input signal. For example, the user can measure the period and duty cycle of the PWM applied on channel 1 using the following procedures:

- Set C1C=2'b01: select C1IN for C1IFP1
- Set C1P=1'b0, select C1IFP1 rising edge active
- Set C2C=2'b10, select C2IN for C1IFP2
- Set C2P=1'b1, select C1IFP2 falling edge active
- Set STIS=3'b101, select the slave mode timer trigger signal as C1IFP1
- Set SMSEL=3'b100: configure the slave mode controller in reset mode
- Set C1EN=1'b1 and C2EN=1'b1. Enable channel 1 and input capture

After above configuration, the rising edge of channel 1 input signal will trigger the capture and stores the capture value into C1DT register, and it will reset the counter at the same time. The falling edge of the channel 1 input signal triggers the capture and stores the capture value into C2DT register. The period of the channel 1 input signal is calculated through C1DT, and its duty cycle through C2DT.

Figure 15-24 PWM input mode configuration example



Figure 15-25 PWM input mode



### 15.2.3.4 TMR output function

The TMR output consists of a comparator and an output controller. It is used to program the period, duty cycle and polarity of the output signal.

Figure 15-26 Capture/compare channel output stage (channel 1 to 4)



#### Output mode

Write  $CxC[2: 0] \neq 2'b00$  to configure the channel as output to support multiple output modes. In this case, the counter value is compared with the value in the  $TMRx\_CxDT$  register, and the intermediate signal  $CxORAW$  is generated according to the output mode selected by  $CxOCTRL[2: 0]$ , which is sent to IO after being processed by the output control circuit. The period of the output signal is configured by the  $TMRx\_PR$  register, while the duty cycle by the  $TMRx\_CxDT$  register.

Output compare modes include:

##### PWM mode A:

Enable PWM mode A by setting  $CxOCTRL=3'b110$ . In upcounting mode,  $C1ORAW$  outputs high when  $TMRx\_C1DT > TMRx\_CVAL$ ; otherwise, it is low. In downcounting mode,  $C1ORAW$  outputs low when  $TMRx\_C1DT < TMRx\_CVAL$ ; otherwise, it is high. Figure 15-27 presents an example of PWM mode A in upcounting mode,  $PR=0x32$ , and  $CxDT$  with different values.

To use PWM mode A, the following procedures are recommended:

- Set PWM period through  $TMRx\_PR$  register
- Set PWM duty cycles through  $TMRx\_CxDT$
- Select PWM mode A by setting  $CxOCTRL=3'b110$  in the  $TMRx\_CM1/CM2$  register
- Set counting frequency through  $TMRx\_DIV$  register
- Select counting mode by setting the  $TWCMSEL[1:0]$  bit in the  $TMRx\_CTRL1$  register
- Select output polarity through the  $CxP$  and  $CxCP$  bits in the  $TMRx\_CCTRL$  register
- Enable channel output through the  $CxEN$  and  $CxCEN$  bits in the  $TMRx\_CCTRL$  register

- Enable TMRx output through the OEN bit in the TMRx\_BRK register
- Configure GPIOs corresponding to TMR output channels as multiplexed mode
- Enable TMRx to start counting through the TMREN bit in the TMRx\_CTRL1 register.

Figure 15-27 PWM mode A in upcounting mode



#### PWM mode B:

Enable PWM mode B by setting CxOCTRL=3'b111. In upcounting mode, C1ORAW outputs low when TMRx\_C1DT>TMRx\_CVAL; otherwise, it is high. In downcounting mode, C1ORAW outputs high when TMRx\_C1DT<TMRx\_CVAL; otherwise, it is low. Figure 15-28 presents an example of PWM mode B in up/down counting mode, PR=0x32, and CxDT with different values.

Figure 15-28 PWM mode B in up/down counting mode



#### Forced output mode:

Enable forced output mode by setting CxOCTRL=3'b100/101. In this case, the CxORAW is forced to be the programmed level, regardless of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.

#### Output compare mode:

Enable output compare mode by setting CxOCTRL=3'b001/010/011. In this case, when the counter value matches the value of the CxDT register, the CxORAW is forced high (CxOCTRL=3'b001), low (CxOCTRL=3'b010) or toggling (CxOCTRL=3'b011). Figure 15-29 presents an example of output compare mode, C1DT=0x3. When the counter value is 0x3, C1OUT toggles.

Figure 15-29 C1ORAW toggles when counter value matches C1DT value

**One-pulse mode:**

This is a particular case of PWM mode. Enable one-pulse by setting OCMEN=1. In this mode, the comparison match is performed in the current counting period. The TMREN bit is cleared as soon as the current counting is completed. Therefore, only one pulse is output. When configured in upcounting mode, the configuration must follow the rule: CVAL<CxDT≤PR; in downcounting mode, CVAL>CxDT is required. Figure 15-30 presents an example of PWM B in upcounting mode & one-pulse mode. The counter counts a single cycle, and only a single pulse is output during this cycle.

Figure 15-30 One-pulse mode

**Fast output mode:**

Enable this mode by setting CxOEN=1. If enabled, the CxORAW signal will not change when the counter value matches the CxDT, but change at the beginning of the current counting period. In other words, the comparison result is advanced, so the comparison result between the counter value and the TMRx\_CxDT register will determine the level of CxORAW in advance.

**Master mode timer event output**

When TMR is used as a master timer, one of the following source of signals can be selected as TRGOUT output to a slave mode timer. This is done by setting the PTOS bit in the TMRxCTRL2 register.

- PTOS=3'b000, TRGOUT output software overflow event (OVFSWTR bit in TMRx\_SWEVT register) or reset event
- PTOS=3'b001, TRGOUT output counter enable
- PTOS=3'b010, TRGOUT output counter overflow event
- PTOS=3'b011, TRGOUT output capture and compare event (C1DT)
- PTOS=3'b100, TRGOUT output C1ORAW
- PTOS=3'b101, TRGOUT output C2ORAW
- PTOS=3'b110, TRGOUT output C3ORAW
- PTOS=3'b111, TRGOUT output C4ORAW

**CxORAW clear**

When the CxOSEN bit is set to 1, the CxORAW signal for a given channel is cleared by applying a high level to the EXT input. The CxORAW signal remains unchanged until the next overflow event.

This function can only be used in output capture or PWM modes, and does not work in forced mode. [Figure 15-31](#) shows the example of clearing CxORAW signal. When the EXT input is high, the CxORAW signal, which was originally high, is driven low; when the EXT is low, the CxORAW signal outputs the corresponding level according to the comparison result between the counter value and CxDT value.

Figure 15-31 Clearing CxORAW(PWM mode B) by EXT input



### 15.2.3.5 TMR synchronization

The timers are linked together internally for timer synchronization. Master timer is selected by setting the PTOS[2: 0] bit; Slave timer is selected by setting the SMSEL[2: 0] bit.

Slave modes include:

#### Slave mode: Reset mode

The counter and its prescaler can be reset by a selected trigger signal. An overflow event is generated when OVFS=0.

Figure 15-32 Example of reset mode



#### Slave mode: Suspend mode

In this mode, the counter is controlled by a selected trigger input. The counter starts counting when the trigger input is high and stops as soon as the trigger input is low.

Figure 15-33 Example of suspend mode



### Slave mode: Trigger mode

The counter can start counting on the rising edge of a selected trigger input (TMR\_EN=1)

Figure 15-34 Example of trigger mode



### Master/slave timer interconnection

Both Master and slave timer can be configured in different master and slave mode scenarios respectively. The combination of both them can be used for various purposes. [Figure 15-35](#) provides an example of interconnection between master timer and slave timer.

Figure 15-35 Master/slave timer connection



#### Using master timer to clock the slave timer:

- Configure master timer output signal TRGOUT as an overflow event (PTOS[2: 0]=3'b010). The master timer outputs a pulse signal at each counter overflow event, which is used as the counting clock of the slave timer.
- Configure the master timer counting period (TMRx\_PR register)
- Configure the slave timer trigger input signal TRGIN as master timer output (STIS[2: 0] in the TMRx\_STCTRL register)
- Configure the slave timer to use external clock mode A (SMSEL[2: 0]=3'b111 in the TMRx\_STCTRL register )
- Set TMREN =1 in both master timer and slave timer to enable them

#### Using master timer to start slave timer:

- Configure master timer output signal TRGOUT as an overflow event (PTOS[2: 0]=3'b010). The master timer outputs a pulse signal at each counter overflow event, which is used as the counting clock of the slave timer.
- Configure master timer counting period (TMRx\_PR registers)
- Configure slave timer trigger input signal TRGIN as master timer input
- Configure slave timer as trigger mode (SMSEL=3'b110 in the TMR2\_STCTRL register)
- Set TMREN=1 to enable master timer.

Figure 15-36 Using master timer to start slave timer

**Starting master and slave timers synchronously by an external trigger:**

In this example, configure the master timer as master and slave mode synchronously and enable its slave timer synchronization function. This mode is used for synchronization between master timer and slave timer.

- Set the STS bit of the master timer.
- Configure master timer output signal TRGOUT as an overflow event (PTOS[2: 0]=3'b010). The master timer outputs a pulse signal at each counter overflow event, which is used as the counting clock of the slave timer.
- Configure the slave timer mode of the master timer as trigger mode, and select C1IN as trigger source
- Configure slave timer trigger input signal TRGIN as master timer output
- Configure slave timer as trigger mode (SMSEL=3'b110 in the TMR2\_STCTRL register)

Figure 15-37 Starting master and slave timers synchronously by an external trigger



### 15.2.3.6 TMR DMA

TMR has the following events for DMA transfer request: overflow event DMA request, trigger event DMA request, Hall sensor DMA request and channel event DMA request. It is possible to enable DMA request by setting the TMRx\_IDEN register. Once enabled, upon an event generated, a DMA request is triggered and output to the DMA peripheral.

#### TMR DMA Burst feature

TMR also supports TMR DMA Burst feature. Thanks to this feature, DMA can be triggered to rewrite multiple TMR consecutive registers by enabling a certain DMA request through the TMRx\_IDEN register.

As an overflow event to trigger TMR DMA Burst as an example:

- Enable overflow event to trigger DMA request using the OVFDEN bit in the TMRx\_IDEN register
- Configure Burst transfer times using the DTB bit in the TMRx\_DMACTRL register

- Configure the start address of Burst transfer using the ADDR bit in the TMRx\_DMACTRL register
- Enable counter

After the above-mentioned configurations, here is the whole process of TMR DMA Burst transfer:

Upon an overflow event, the TMR will send a DMA request to the DMA peripheral. Then the DMA writes the data into the TMRx\_DMADT register as requested. Inside TMR, the DMADT bit data is written into the start address register of Burst transfer and an ACK single is sent to TMR. After receiving this ACK, the TMR clears the current DMA request; when the Burst transfer is detected by the TMR not to complete fully, a new overflow event for DMA request is released to the DMA so that the DMA writes the requested data into the TMRx\_DMADT again. In this case, inside tmr, the DMADT register data is written into the Burst transfer start address + 0x4 address register, and a new ACK is sent to TMR, and so on, and so on, until the last operation of Burst transfer. When a full Burst transfer is complete, the REQ for overflow event DMA request would not be set any more until the next overflow event.

*Note: when using TMR DMA Burst feature, an empty register is prohibited and the TMRx\_DMACTRL as well as TMRx\_DMADT registers should not be available during the period from the start address to the end address.*

### 15.2.3.7 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the TMRx counter stops counting by setting the TMRx\_PAUSE in the DEBUG module.

### 15.2.4 TMR2 to TMR4 registers

These peripheral registers have to be accessed by half words (16 bits) or words (32 bits).

Table 15-5 TMR2 to TMR4 register map and reset value

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| TMRx_CTRL1   | 0x00   | 0x0000 0000 |
| TMRx_CTRL2   | 0x04   | 0x0000 0000 |
| TMRx_STCTRL  | 0x08   | 0x0000 0000 |
| TMRx_IDEN    | 0x0C   | 0x0000 0000 |
| TMRxISTS     | 0x10   | 0x0000 0000 |
| TMRxSWEVT    | 0x14   | 0x0000 0000 |
| TMRx_CM1     | 0x18   | 0x0000 0000 |
| TMRx_CM2     | 0x1C   | 0x0000 0000 |
| TMRx_CCTRL   | 0x20   | 0x0000 0000 |
| TMRx_CVAL    | 0x24   | 0x0000 0000 |
| TMRx_DIV     | 0x28   | 0x0000 0000 |
| TMRx_PR      | 0x2C   | 0x0000 FFFF |
| TMRx_C1DT    | 0x34   | 0x0000 0000 |
| TMRx_C2DT    | 0x38   | 0x0000 0000 |
| TMRx_C3DT    | 0x3C   | 0x0000 0000 |
| TMRx_C4DT    | 0x40   | 0x0000 0000 |
| TMRx_DMACTRL | 0x48   | 0x0000 0000 |
| TMRx_DMADT   | 0x4C   | 0x0000 0000 |
| TMR2_RMP     | 0x50   | 0x0000 0000 |

### 15.2.4.1 TMRx control register 1 (TMRx\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 11 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|            |          |             |      | Plus Mode Enable<br>This bit is used to enable TMR2 plus mode. In this mode, TMR2_CVAL, TMR2_PR and TMR2_CxDT are extended from 16-bit to 32-bit.                                                                                                                                                                                                                                                                                                                                                          |
| Bit 10     | PMEN     | 0x0         | rw   | 0: Disabled<br>1: Enabled<br>Note: This function is only valid for TMR2. It is not applicable to other TMRs. In plus mode or when disabled, only 16-bit value can be written to TMR2_CVAL, TMR2_PR and TMR2_CxDT registers.                                                                                                                                                                                                                                                                                |
|            |          |             |      | Clock division<br>This bit is used to select the division ratio between $f_{DTS}$ (digital filter sampling frequency) and the ( $f_{CK\_INT}$ ) timer clock frequency<br>00: No division, $f_{DTS}=f_{CK\_INT}$<br>01: Divided by 2, $f_{DTS}=f_{CK\_INT}/2$<br>10: Divided by 4, $f_{DTS}=f_{CK\_INT}/4$<br>11: Reserved                                                                                                                                                                                  |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | Period buffer enable<br>0: Period buffer is disabled<br>1: Period buffer is enabled                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 7      | PRBEN    | 0x0         | rw   | Two-way counting mode selection<br>00: One-way counting mode, depending on the OWCDIR bit<br>01: Two-way counting mode 1. The counter counts up and down alternately, the CxIF bit is set only when the counter is counting down<br>10: Two-way counting mode 2. The counter counts up and down alternately, the CxIF bit is set only when the counter is counting up<br>11: Two-way counting mode 3. The counter counts up and down alternately, the CxIF bit is set when the counter counting up or down |
| Bit 6: 5   | TWCMSEL  | 0x0         | rw   | One-way count direction<br>0: Up<br>1: Down                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 4      | OWCDIR   | 0x0         | rw   | One cycle mode enable<br>This bit is use to select whether to stop counting at an overflow event<br>0: The counter does not stop at an overflow event<br>1: The counter stops at an overflow event                                                                                                                                                                                                                                                                                                         |
| Bit 3      | OCMEN    | 0x0         | rw   | Overflow event source<br>This bit is used to select overflow event or DMA request sources.<br>0: Counter overflow, setting the OVFSWTR bit or overflow event generated by slave timer controller<br>1: Only counter overflow generates an overflow event                                                                                                                                                                                                                                                   |
| Bit 2      | OVFS     | 0x0         | rw   | Overflow event enable<br>0: Enabled<br>1: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 1      | OVFEN    | 0x0         | rw   | TMR enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 0      | TMREN    | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 15.2.4.2 TMRx control register 2 (TMRx\_CTRL2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                            |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at its default value.                                                                                                                             |
|           |          |             |      | C1IN selection<br>0: CH1 pin is connected to C1IRAW input<br>1: The XOR result of CH1, CH2 and CH3 pins is connected to C1IRAW input                   |
| Bit 7     | C1INSEL  | 0x0         | rw   |                                                                                                                                                        |
|           |          |             |      | Master TMR output selection<br>This field is used to select the TMRx signal sent to the slave timer.<br>000: Software overflow or Reset<br>001: Enable |
| Bit 6: 4  | PTOS     | 0x0         | rw   | 010: Overflow<br>011: Compare pulse (C1DT)<br>100: C1ORAW signal<br>101: C2ORAW signal<br>110: C3ORAW signal<br>111: C4ORAW signal                     |
| Bit 3     | DRS      | 0x0         | rw   | DMA request source<br>0: Capture/compare event<br>1: Overflow event                                                                                    |
| Bit 2: 0  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                             |

### 15.2.4.3 TMRx slave timer control register (TMRx\_STCTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 15     | ESP      | 0x0         | rw   | External signal polarity<br>0: High or rising edge<br>1: Low or falling edge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 14     | ECMBEN   | 0x0         | rw   | External clock mode B enable<br>This bit is used to enable external clock mode B<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 13: 12 | ESDIV    | 0x0         | rw   | External signal divider<br>This field is used to select the frequency division factor of an external trigger<br>00: Normal<br>01: Divided by 2<br>10: Divided by 4<br>11: Divided by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 11: 8  | ESF      | 0x0         | rw   | External signal filter<br>This field is used to filter an external signal. The external signal can be sampled only after it has been generated N times<br>0000: No filter, sampling by $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
| Bit 7      | STS      | 0x0         | rw   | Subordinate TMR synchronization<br>If enabled, master and slave timer can be synchronized.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 6: 4 | STIS     | 0x0 | rw   | Subordinate TMR input selection<br>This field is used to select the input of subordinate TMR.<br>000: Internal selection 0 (IS0)<br>001: Internal selection 1 (IS1)<br>010: Internal selection 2 (IS2)<br>011: Internal selection 3 (IS3)<br>100: C1IRAW input detector (C1INC)<br>101: Filtered input 1 (C1IF1)<br>110: Filtered input 2 (C1IF2)<br>111: External input (EXT)<br>Please refer to Table 14-3 for more information on ISx for each timer.                                                                                                  |
| Bit 3    | Reserved | 0x0 | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 2: 0 | SMSEL    | 0x0 | rw   | Subordinate TMR mode selection<br>000: Slave mode is disabled<br>001: Encoder mode A<br>010: Encoder mode B<br>011: Encoder mode C<br>100: Reset mode — Rising edge of the TRGIN input reinitializes the counter<br>101: Suspend mode — The counter starts counting when the TRGIN is high<br>110: Trigger mode — A trigger event is generated at the rising edge of the TRGIN input<br>111: External clock mode A — Rising edge of the TRGIN input clocks the counter<br>Note: Please refer to count mode section for the details on encoder mode A/B/C. |

#### 15.2.4.4 TMRx DMA/interrupt enable register (TMRx\_IDEN)

| Bit       | Name     | Reset value | Type | Description                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------|
| Bit 31:15 | Reserved | 0x0 0000    | resd | Kept at default value                                          |
| Bit 14    | TDEN     | 0x0         | rw   | Trigger DMA request enable<br>0: Disabled<br>1: Enabled        |
| Bit 13    | Reserved | 0x0         | resd | Kept at default value                                          |
| Bit 12    | C4DEN    | 0x0         | rw   | Channel 4 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 11    | C3DEN    | 0x0         | rw   | Channel 3 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 10    | C2DEN    | 0x0         | rw   | Channel 2 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 9     | C1DEN    | 0x0         | rw   | Channel 1 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 8     | OVFDEN   | 0x0         | rw   | Overflow event DMA request enable<br>0: Disabled<br>1: Enabled |
| Bit 7     | Reserved | 0x0         | resd | Kept at default value                                          |
| Bit 6     | TIEN     | 0x0         | rw   | Trigger interrupt enable<br>0: Disabled<br>1: Enabled          |
| Bit 5     | Reserved | 0x0         | resd | Kept at default value                                          |
| Bit 4     | C4IEN    | 0x0         | rw   | Channel 4 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 3     | C3IEN    | 0x0         | rw   | Channel 3 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 2     | C2IEN    | 0x0         | rw   | Channel 2 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 1     | C1IEN    | 0x0         | rw   | Channel 1 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 0     | OVFIEN   | 0x0         | rw   | Overflow interrupt enable<br>0: Disabled<br>1: Enabled         |

#### 15.2.4.5 TMRx interrupt status register (TMRxISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 13 | Reserved | 0x0 0000    | resd | Kept at default value                                                                                                                                                                                        |
| Bit 12     | C4RF     | 0x0         | rw0c | Channel 4 recapture flag<br>Please refer to C1RF description.                                                                                                                                                |
| Bit 11     | C3RF     | 0x0         | rw0c | Channel 3 recapture flag<br>Please refer to C1RF description.                                                                                                                                                |
| Bit 10     | C2RF     | 0x0         | rw0c | Channel 2 recapture flag<br>Please refer to C1RF description.                                                                                                                                                |
| Bit 9      | C1RF     | 0x0         | rw0c | Channel 1 recapture flag<br>This bit indicates whether a recapture is detected when C1IF=1. This bit is set by hardware, and cleared by writing "0".<br>0: No capture is detected<br>1: Capture is detected. |
| Bit 8: 7   | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                        |
| Bit 6      | TRGIF    | 0x0         | rw0c | Trigger interrupt flag<br>This bit is set by hardware on a trigger event. It is cleared by writing "0".                                                                                                      |

|       |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 0: No trigger event occurred<br>1: Trigger event is generated.<br>Trigger event: an active edge is detected on TRGIN input, or any edge in suspend mode.                                                                                                                                                                                                                                                                                                 |
| Bit 5 | Reserved | 0x0 | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 4 | C4IF     | 0x0 | rw0c | Channel 4 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 3 | C3IF     | 0x0 | rw0c | Channel 3 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 2 | C2IF     | 0x0 | rw0c | Channel 2 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 1 | C1IF     | 0x0 | rw0c | Channel 1 interrupt flag<br>If the channel 1 is configured as input mode:<br>This bit is set by hardware on a capture event. It is cleared by software or read access to the TMRx_C1DT<br>0: No capture event occurred<br>1: Capture event is generated<br>If the channel 1 is configured as output mode:<br>This bit is set by hardware on a compare event. It is cleared by software.<br>0: No compare event occurred<br>1: Compare event is generated |
| Bit 0 | OVFIF    | 0x0 | rw0c | Overflow interrupt flag<br>This bit is set by hardware on an overflow event. It is cleared by software.<br>0: No overflow event occurred<br>1: Overflow event is generated. If OVFEN=0 and OVFS=0 in the TMRx_CTRL1 register:<br>– An overflow event is generated when OVFSWTR= 1 in the TMRx_SWEVT register;<br>– An overflow event is generated when the counter CVAL is reinitialized by a trigger event.                                             |

#### 15.2.4.6 TMRx software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                           |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x000 0000  | resd | Kept at default value.                                                                                                                                |
| Bit 6     | TRGSWTR  | 0x0         | rw   | Trigger event triggered by software<br>This bit is set by software to generate a trigger event.<br>0: No effect<br>1: Generate a trigger event.       |
| Bit 5     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                |
| Bit 4     | C4SWTR   | 0x0         | wo   | Channel 4 event triggered by software<br>Please refer to C1SWTR description.                                                                          |
| Bit 3     | C3SWTR   | 0x0         | wo   | Channel 3 event triggered by software<br>Please refer to C1SWTR description.                                                                          |
| Bit 2     | C2SWTR   | 0x0         | wo   | Channel 2 event triggered by software<br>Please refer to C1SWTR description                                                                           |
| Bit 1     | C1SWTR   | 0x0         | wo   | Channel 1 event triggered by software<br>This bit is set by software to generate a channel 1 event.<br>0: No effect<br>1: Generate a channel 1 event. |
| Bit 0     | OVFSWTR  | 0x0         | wo   | Overflow event triggered by software<br>This bit is set by software to generate an overflow event.<br>0: No effect<br>1: Generate an overflow event.  |

### 15.2.4.7 TMRx channel mode register 1 (TMRx\_CM1)

#### Output compare mode:

| Bit                                                                                                                                                                                                                                                                                                                                                                          | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16                                                                                                                                                                                                                                                                                                                                                                   | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 15                                                                                                                                                                                                                                                                                                                                                                       | C2OSEN   | 0x0         | rw   | Channel 2 output switch enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 14: 12                                                                                                                                                                                                                                                                                                                                                                   | C2OCTRL  | 0x0         | rw   | Channel 2 output control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 11                                                                                                                                                                                                                                                                                                                                                                       | C2OBEN   | 0x0         | rw   | Channel 2 output buffer enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 10                                                                                                                                                                                                                                                                                                                                                                       | C2OIEN   | 0x0         | rw   | Channel 2 output enable immediately                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Channel 2 configuration<br>This field is used to define the direction of the channel 2 (input or output), and the selection of input pin when C2EN='0':<br>00: Output<br>01: Input, C2IN is mapped on C2IFP2<br>10: Input, C2IN is mapped on C1IFP2<br>11: Input, C2IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS register. |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 9: 8                                                                                                                                                                                                                                                                                                                                                                     | C2C      | 0x0         | rw   | Channel 1 output switch enable<br>0: C1ORAW is not affected by EXT<br>1: Once high level is detect on EXT input, clear C1ORAW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 7                                                                                                                                                                                                                                                                                                                                                                        | C1OSEN   | 0x0         | rw   | Channel 1 output control<br>This field defines the behavior of the original signal C1ORAW.<br>000: Disconnected. C1ORAW is disconnected from C1OUT;<br>001: C1ORAW is high when TMRx_CVAL=TMRx_C1DT<br>010: C1ORAW is low when TMRx_CVAL=TMRx_C1DT<br>011: Switch C1ORAW level when TMRx_CVAL=TMRx_C1DT<br>100: C1ORAW is forced low<br>101: C1ORAW is forced high.<br>110: PWM mode A<br>—OWCDIR=0, C1ORAW is high once TMRx_C1DT>TMRx_CVAL, else low;<br>—OWCDIR=1, C1ORAW is low once TMRx_C1DT<TMRx_CVAL, else high;<br>111: PWM mode B<br>—OWCDIR=0, C1ORAW is low once TMRx_C1DT>TMRx_CVAL, else high;<br>—OWCDIR=1, C1ORAW is high once TMRx_C1DT<TMRx_CVAL, else low.<br><i>Note: In the configurations other than 000', the C1OUT is connected to C1ORAW. The C1OUT output level is not only subject to the changes of C1ORAW, but also the output polarity set by CCTRL.</i> |
| Bit 6: 4                                                                                                                                                                                                                                                                                                                                                                     | C1OCTRL  | 0x0         | rw   | Channel 1 output buffer enable<br>0: Buffer function of TMRx_C1DT is disabled. The new value written to the TMRx_C1DT takes effect immediately.<br>1: Buffer function of TMRx_C1DT is enabled. The value to be written to the TMRx_C1DT is stored in the buffer register, and can be sent to the TMRx_C1DT register only on an overflow event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 3                                                                                                                                                                                                                                                                                                                                                                        | C1OBEN   | 0x0         | rw   | Channel 1 output enable immediately<br>In PWM mode A or B, this bit is used to accelerate the channel 1 output's response to the trigger event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 2                                                                                                                                                                                                                                                                                                                                                                        | C1OIEN   | 0x0         | rw   | 0: Need to compare the CVAL with C1DT before generating an output<br>1: No need to compare the CVAL and C1DT. An output is generated immediately when a trigger event occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 1: 0                                                                                                                                                                                                                                                                                                                                                                     | C1C      | 0x0         | rw   | Channel 1 configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':  
 00: Output  
 01: Input, C1IN is mapped on C1IFP1  
 10: Input, C1IN is mapped on C2IFP1  
 11: Input, C1IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.

**Input capture mode:**

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 15: 12 | C2DF     | 0x0         | rw   | Channel 2 digital filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 11: 10 | C2IDIV   | 0x0         | rw   | Channel 2 input divider                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 9: 8   | C2C      | 0x0         | rw   | Channel 2 configuration<br>This field is used to define the direction of the channel 2 (input or output), and the selection of input pin when C2EN='0':<br>00: Output<br>01: Input, C2IN is mapped on C2IFP2<br>10: Input, C2IN is mapped on C1IFP2<br>11: Input, C2IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 7: 4   | C1DF     | 0x0         | rw   | Channel 1 digital filter<br>This field defines the digital filter of the channel 1. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output.<br>0000: No filter, sampling is done at $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
| Bit 3: 2   | C1IDIV   | 0x0         | rw   | Channel 1 input divider<br>This field defines Channel 1 input divider.<br>00: No divider. An input capture is generated at each active edge.<br>01: An input compare is generated every 2 active edges<br>10: An input compare is generated every 4 active edges<br>11: An input compare is generated every 8 active edges<br>Note: the divider is reset once C1EN='0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 1: 0   | C1C      | 0x0         | rw   | Channel 1 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':<br>00: Output<br>01: Input, C1IN is mapped on C1IFP1<br>10: Input, C1IN is mapped on C2IFP1<br>11: Input, C1IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 15.2.4.8 TMRx channel mode register 2 (TMRx\_CM2)

#### Output compare mode:

| Bit                                                                                                                          | Name     | Reset value | Type | Description                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16                                                                                                                   | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                   |
| Bit 15                                                                                                                       | C4OSEN   | 0x0         | rw   | Channel 4 output switch enable                                                                                                                                                                           |
| Bit 14: 12                                                                                                                   | C4OCTRL  | 0x0         | rw   | Channel 4 output control                                                                                                                                                                                 |
| Bit 11                                                                                                                       | C4OBEN   | 0x0         | rw   | Channel 4 output buffer enable                                                                                                                                                                           |
| Bit 10                                                                                                                       | C4OIEN   | 0x0         | rw   | Channel 4 output enable immediately                                                                                                                                                                      |
| Channel 4 configuration                                                                                                      |          |             |      |                                                                                                                                                                                                          |
| This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C4EN='0': |          |             |      |                                                                                                                                                                                                          |
| Bit 9: 8                                                                                                                     | C4C      | 0x0         | rw   | 00: Output<br>01: Input, C4IN is mapped on C4IFP4<br>10: Input, C4IN is mapped on C3IFP4<br>11: Input, C4IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |
| Bit 7                                                                                                                        | C3OSEN   | 0x0         | rw   | Channel 3 output switch enable                                                                                                                                                                           |
| Bit 6: 4                                                                                                                     | C3OCTRL  | 0x0         | rw   | Channel 3 output control                                                                                                                                                                                 |
| Bit 3                                                                                                                        | C3OBEN   | 0x0         | rw   | Channel 3 output buffer enable                                                                                                                                                                           |
| Bit 2                                                                                                                        | C3OIEN   | 0x0         | rw   | Channel 3 output enable immediately                                                                                                                                                                      |
| Channel 3 configuration                                                                                                      |          |             |      |                                                                                                                                                                                                          |
| This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C3EN='0': |          |             |      |                                                                                                                                                                                                          |
| Bit 1: 0                                                                                                                     | C3C      | 0x0         | rw   | 00: Output<br>01: Input, C3IN is mapped on C3IFP3<br>10: Input, C3IN is mapped on C4IFP3<br>11: Input, C3IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |

#### Input capture mode:

| Bit                                                                                                                          | Name     | Reset value | Type | Description                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16                                                                                                                   | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                   |
| Bit 15: 12                                                                                                                   | C4DF     | 0x0         | rw   | Channel 4 digital filter                                                                                                                                                                                 |
| Bit 11: 10                                                                                                                   | C4IDIV   | 0x0         | rw   | Channel 4 input divider                                                                                                                                                                                  |
| Channel 4 configuration                                                                                                      |          |             |      |                                                                                                                                                                                                          |
| This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C4EN='0': |          |             |      |                                                                                                                                                                                                          |
| Bit 9: 8                                                                                                                     | C4C      | 0x0         | rw   | 00: Output<br>01: Input, C4IN is mapped on C4IFP4<br>10: Input, C4IN is mapped on C3IFP4<br>11: Input, C4IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |
| Bit 7: 4                                                                                                                     | C3DF     | 0x0         | rw   | Channel 3 digital filter                                                                                                                                                                                 |
| Bit 3: 2                                                                                                                     | C3IDIV   | 0x0         | rw   | Channel 3 input divider                                                                                                                                                                                  |
| Channel 3 configuration                                                                                                      |          |             |      |                                                                                                                                                                                                          |
| This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C3EN='0': |          |             |      |                                                                                                                                                                                                          |
| Bit 1: 0                                                                                                                     | C3C      | 0x0         | rw   | 00: Output<br>01: Input, C3IN is mapped on C3IFP3<br>10: Input, C3IN is mapped on C4IFP3<br>11: Input, C3IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |

### 15.2.4.9 TMRx channel control register (TMRx\_CCTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 13     | C4P      | 0x0         | rw   | Channel 4 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 12     | C4EN     | 0x0         | rw   | Channel 4 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 11     | C3CP     | 0x0         | rw   | Channel 3 complementary polarity<br>This bit defines the valid edge of input signals. Refer to C1P bit for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 10     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 9      | C3P      | 0x0         | rw   | Channel 3 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 8      | C3EN     | 0x0         | rw   | Channel 3 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 7      | C2CP     | 0x0         | rw   | Channel 2 complementary polarity<br>This bit defines the valid edge of input signals. Refer to C1P bit for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 6      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 5      | C2P      | 0x0         | rw   | Channel 2 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 4      | C2EN     | 0x0         | rw   | Channel 2 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 3      | C1CP     | 0x0         | rw   | Channel 1 complementary polarity<br>This bit defines the valid edge of input signals. Refer to C1P bit for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 2      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 1      | C1P      | 0x0         | rw   | Channel 1 polarity<br>When the channel 1 is configured as output mode:<br>0: C1OUT is active high<br>1: C1OUT is active low<br>When the channel 1 is configured as input mode:<br>C1CP/C1P are used to define the valid edge of input signals.<br>00: C1IN active edge is on its rising edge. When used as external trigger, C1IN is not inverted.<br>01: C1IN active edge is on its falling edge. When used as external trigger, C1IN is inverted.<br>10: Reserved<br>11: C1IN rising and falling edges active. When used as external trigger, C1IN is not inverted. |
| Bit 0      | C1EN     | 0x0         | rw   | Channel 1 enable<br>0: Input or output is disabled<br>1: Input or output is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Table 15-6 Standard CxOUT channel output control bit

| CxEN bit | CxOUT output state                 |
|----------|------------------------------------|
| 0        | Output disabled (CxOUT=0, Cx_EN=0) |
| 1        | CxOUT = CxORAW + polarity, Cx_EN=1 |

Note: The state of the external I/O pins connected to the standard CxOUT channel depends on the CxOUT channel state and the GPIO and IOMUX registers.

#### 15.2.4.10 TMRx counter value register (TMRx\_CVAL)

| Bit        | Name | Reset value | Type | Description                                                                                                             |
|------------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | CVAL | 0x0000      | rw   | Counter value<br>When TMR2 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the CVAL is extended to 32 bits. |
| Bit 15: 0  | CVAL | 0x0000      | rw   | Counter value                                                                                                           |

#### 15.2.4.11 TMRx frequency division value register (TMRx\_DIV)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                       |
| Bit 15: 0  | DIV      | 0x0000      | rw   | Divider value<br>The counter clock frequency $f_{CK\_CNT} = f_{TMR\_CLK} / (\text{DIV}[15:0] + 1)$ .<br>DIV contains the value written at an overflow event. |

#### 15.2.4.12 TMRx period register (TMRx\_PR)

| Bit        | Name | Reset value | Type | Description                                                                                                            |
|------------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | PR   | 0x0000      | rw   | Period value<br>When TMR2 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the PR is extended to 32 bits.   |
| Bit 15: 0  | PR   | 0xFFFF      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

#### 15.2.4.13 TMRx channel 1 data register (TMRx\_C1DT)

| Bit        | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | C1DT | 0x0000      | rw   | Channel 1 data register<br>When TMR2 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the C1DT is extended to 32 bits.                                                                                                                                                                                                                                                                                             |
| Bit 15: 0  | C1DT | 0x0000      | rw   | Channel 1 data register<br>When the channel 1 is configured as input mode:<br>The C1DT is the CVAL value stored by the last channel 1 input event (C1IN).<br><br>When the channel 1 is configured as output mode:<br>C1DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C1OBEN bit, and the corresponding output is generated on C1OUT as configured. |

#### 15.2.4.14 TMRx channel 2 data register (TMRx\_C2DT)

| Bit        | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | C2DT | 0x0000      | rw   | Channel 2 data register<br>When TMR2 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the C2DT is expanded to 32 bits.                                                                                                                                                                                                                                                                                             |
| Bit 15: 0  | C2DT | 0x0000      | rw   | Channel 2 data register<br>When the channel 2 is configured as input mode:<br>The C2DT is the CVAL value stored by the last channel 2 input event (C2IN).<br><br>When the channel 2 is configured as output mode:<br>C2DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C2OBEN bit, and the corresponding output is generated on C2OUT as configured. |

#### 15.2.4.15 TMRx channel 3 data register (TMRx\_C3DT)

| Bit        | Name | Reset value | Type | Description                                                                                                                       |
|------------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | C3DT | 0x0000      | rw   | Channel 3 data register<br>When TMR2 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the C3DT is expanded to 32 bits. |
| Bit 15: 0  | C3DT | 0x0000      | rw   | Channel 3 data register                                                                                                           |

When the channel 3 is configured as input mode:  
 The C3DT is the CVAL value stored by the last channel 3 input event (C3IN).  
 When the channel 3 is configured as output mode:  
 C3DT is the value to be compared with the CVAL value.  
 Whether the written value takes effect immediately depends on the C3OBEN bit, and the corresponding output is generated on C3OUT as configured.

#### 15.2.4.16 TMRx channel 4 data register (TMRx\_C4DT)

| Bit        | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | C4DT | 0x0000      | rw   | Channel 4 data register<br>When TMR2 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the C4DT is expanded to 32 bits.                                                                                                                                                                                                                                                                                         |
| Bit 15: 0  | C4DT | 0x0000      | rw   | Channel 4 data register<br>When the channel 4 is configured as input mode:<br>The C4DT is the CVAL value stored by the last channel 4 input event (C4IN).<br>When the channel 4 is configured as output mode:<br>C4DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C4OBEN bit, and the corresponding output is generated on C4OUT as configured. |

#### 15.2.4.17 TMRx DMA control register (TMRx\_DMACTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                       |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 13 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                            |
| Bit 12: 8  | DTB      | 0x00        | rw   | DMA transfer bytes<br>This field defines the number of DMA transfers:<br>00000: 1 byte      00001: 2 bytes<br>00010: 3 bytes      00011: 4 bytes<br>.....<br>10000: 17 bytes      10001: 18 bytes |
| Bit 7: 5   | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                            |
| Bit 4: 0   | ADDR     | 0x00        | rw   | DMA transfer address offset<br>ADDR is defined as an offset starting from the address of the TMRx_CTRL1 register.<br>00000: TMRx_CTRL1<br>00001: TMRx_CTRL2<br>00010: TMRx_STCTRL<br>.....        |

#### 15.2.4.18 TMRx DMA data register (TMRx\_DMADT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                     |
| Bit 15: 0  | DMADT    | 0x0000      | rw   | DMA data register<br>A read or write operation to the DMADT register accesses the TMR registers at the following address:<br>TMRx peripheral address + ADDR*4 to TMRx peripheral address + ADDR*4 + DTB*4. |

#### 15.2.4.19 TMR2 channel input remap register (TMR2\_RMP)

| Bit        | Name          | Reset value | Type | Description                                              |
|------------|---------------|-------------|------|----------------------------------------------------------|
| Bit 31: 12 | Reserved      | 0x0 0000    | resd | Kept at default value                                    |
| Bit 11: 10 | TMR2_IS3_IRMP | 0x0         | rw   | TMR2 IS3 input remap<br>x0: OTG_FS_SOF<br>x1: OTG_HS_SOF |
| Bit 9: 0   | Reserved      | 0x000       | resd | Kept at default value                                    |

## 15.3 General-purpose timer (TMR9)

### 15.3.1 TMR9 introduction

The general-purpose timer (TMR9) consists of a 16-bit counter supporting upcounting mode. It has two capture/compare registers, and two independent channels for dead-time insertion, input capture and programmable PWM output.

### 15.3.2 TMR9 main features

- Counter clock source: internal clock, external input and internal trigger inputs
- 16-bit upcounter, 8-bit repetition counter
- 2x independent channels for input capture, output compare, PWM generation, one-pulse mode and dead-time insertion
- 1x independent channel with complementary channel
- TMR brake feature
- Synchronization circuit to interconnect several timers together
- Interrupt/DMA generation on at overflow, trigger event, brake input and channel events

Figure 15-38 Block diagram of general-purpose TMR9



### 15.3.3 TMR9 functional overview

#### 15.3.3.1 Counting clock

The counter clock of TMR9 can be provided by the internal clock (CK\_INT), external clock (external clock mode A) and internal trigger input (ISx).

Figure 15-39 Counting clock



### Internal clock (CK\_INT)

By default, the CK\_INT, which is divided by a prescaler, is used to drive the counter to count. When TMR's APB clock prescaler factor is 1, the CK\_INT frequency is equal to that of the APB; otherwise, it doubles the APB clock frequency.

Follow the procedures below:

- Select counting mode by setting the TWCMSEL[1:0] in TMRx\_CTRL1 register. If a unidirectional aligned counting mode is selected, there is a need to select counting direction through the OWCDIR in TMRx\_CTRL1 register.
- Set counting frequency through TMRx\_DIV register
- Set counting cycles through TMRx\_PR register
- Enable the counter by setting the TMREN bit in the TMRx\_CTRL1 register

Figure 15-40 Control circuit with CK\_INT, TMRx\_DIV=0x0 and TMRx\_PR=0x16



### External clock (TRGIN/EXT)

The counter clock can be provided by the external clock source TRGIN.

**SMSEL=3'b111:** External clock mode A is selected. Select an external clock source TRGIN signal by setting the STIS[2: 0] bit to drive the counter to start counting.

The external clock sources include:

C1INC (STIS=3'b100, channel 1 rising edge and falling edge)

C1IFP1 (STIS=3'b101, the channel 1 signal with filtering and polarity selection)

C2IFP2 (STIS=3'b110, a channel 2 signal with filtering and polarity selection).

#### To use external clock mode A, follow the steps below:

- Set external source TRGIN parameters
  - If the TMRx\_CH1 is used as a source of TRGIN, it is necessary to configure channel 1 input filter (C1DF[3:0] in TMRx\_CM1 register) and channel 1 input polarity (C1P/C1CP in TMRx\_CCTRL register);
  - If the TMRx\_CH2 is used as source of TRGIN, it is necessary to configure channel 1 input filter (C2DF[3:0] in TMRx\_CM1 register) and channel 2 input polarity (C2P/C2CP in TMRx\_CCTRL register);
- Set TRGIN signal source using the STIS[1:0] bit in TMRx\_STCTRL register
- Enable external clock mode A by setting SMSEL=3'b111 in TMRx\_STCTR register
- Set counting frequency through the DIV[15:0] in TMRx\_DIV register
- Set counting period through the PR[15:0] in TMRx\_PR register
- Enable counter through the TMREN bit in TMRx\_CTRL1 register

Figure 15-41 Block diagram of external clock mode A



*Note: The delay between the signal on the input side and the actual clock of the counter is due to the synchronization circuit.*

Figure 15-42 Counting in external clock mode A, PR=0x32 and DIV=0x0



#### Internal trigger input (ISx)

Timer synchronization allows interconnection between several timers. The TMR\_CLK of one timer can be provided by the TRGOUT signal from another timer. The internal trigger signal is selected by setting the STIS[2:0] bit to enable counting.

TMR9 consists of a 16-bit prescaler, which is used to generate the CK\_CNT that enables the counter to count. The frequency division relationship between the CK\_CNT and TMR\_CLK can be adjusted by setting the value of the TMRx\_DIV register. The prescaler value can be modified at any time, but the new prescaler value is taken into account when the next overflow event occurs.

#### Below is the configuration procedure for internal trigger input:

- Set counting cycles through TMRx\_PR register
- Set counting frequency through TMRx\_DIV register
- Set counting modes through the TWCMSEL[1:0] in TMRx\_CTRL1 register
- Select internal trigger by setting STIS[2:0]= 3'b000~3'b011 in TMRx\_STCTRL register
- Select external clock mode A by setting SMSEL[2:0]=3'b111 in TMRx\_STCTRL register
- Enable TMRx to start counting through the TMREN in TMRx\_CTRL1 register

Table 15-7 TMRx internal trigger connection

| Slave controller | IS0<br>(STIS = 000) | IS1<br>(STIS = 001) | IS2<br>(STIS = 010) | IS3<br>(STIS = 011) |
|------------------|---------------------|---------------------|---------------------|---------------------|
| TMR9             | TMR2                | TMR3                | TMR10_C1OUT         | TMR11_C1OUT         |

Figure 15-43 Counter timing with prescaler value change from 0 to 3



### 15.3.3.2 Counting mode

The general-purpose timer (TMR9) consists of a 16-bit counter supporting multiple counting modes to meet different application scenarios.

The TMRx\_PR register is used to define counting period of counter. The value in the TMRx\_PR is immediately moved to the shadow register by default. When the periodic buffer is enabled (PRBEN=1), the value in the TMRx\_PR register is transferred to the shadow register only at an overflow event.

TMRx\_DIV register is used to define the counter frequency of the counter. The counter counts once every DIV[15:0]+1 clock cycle. The value of the TMRx\_DIV register are transferred into the shadow register at each overflow event.

Reading the TMRx\_CNT register returns the current counter value. Writing the TMRx\_CNT register will update the current counter value.

An overflow event is enabled by default. It can be disabled by setting OVFEN=1 in the TMRx\_CTRL1 register. The OVFS bit in the TMRx\_CTRL1 register is used to select the source of an overflow event, which is, by default, counter overflow or underflow, setting OVFSWTR, reset signal generated by slave mode timer controller in reset mode. Once the OVFS is set, an overflow event is generated only when overflow or underflow occurs.

Setting the TMREN bit (TMREN=1) enables the timer to start counting. Base on synchronization logic, however, the actual enable signal TMR\_EN is set 1 clock cycle after the TMREN is set.

Figure 15-44 Basic structure of a counter



#### Upcounting mode

This mode is enabled by setting CMSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register.

In upcounting mode, the counter counts from 0 to the value programmed in the TMRx\_PR register, restarts from 0, and generates a counter overflow event, with setting OVFIF bit to 1. If the overflow event is disabled, the counter is no longer reloaded with the prescaler and period value on counter overflow; otherwise, the prescaler and period value will be updated on an overflow event.

Figure 15-45 Overflow event when PRBEN=0



Figure 15-46 Overflow event when PRBEN=1



### Downcounting mode

This mode is enabled by setting TWCSEL[1:0]=2'b00 and OWCDIR=1'b1 in the TMRx\_CTRL1 register. In downcounting mode, the counter counts from the value programmed in the TMRx\_PR register down to 0, and restarts from the value programmed, and generates a counter underflow event.

Figure 15-47 Counter timing diagram with internal clock divided by 3



### Up/down counting mode (center-aligned mode)

This mode is selected by setting TWCSEL[1:0]≠2'b00 in the TMRx\_CTRL1 register.

In up/down counting mode, the counter counts up/down alternatively. When the counter counts from the value programmed in the TMRx\_PR register down to 1, an underflow event is generated, and then restarts counting from 0; when the counter counts from 0 to the value of the TMRx\_PR register -1, an overflow event is generated, and then restarts counting from the value of the TMRx\_PR register. The OWCDIR bit indicates the current counting direction.

The TWCSEL[1:0] bit in the TMRx\_CTRL1 register is used to select the condition under which the CxIF flag is set in two-way counting mode. In other words, when TWCSEL[1:0]=2'b01 (counting mode 1) is selected, the CxIF flag is set only when the counter counts down; when TWCSEL[1:0]=2'b10 (counting mode 2) is selected, the CxIF flag is set only when the counter counts up; when TWCSEL[1:0]=2'b11 (counting mode 3) is selected, the CxIF flag is set when the counter counts up and down.

*Note: The OWCDIR is read-only in up/down counting mode.*

Figure 15-48 Counter timing diagram with internal clock divided by 0 and TMRx\_PR=0x32

**Repetition counter mode:**

The TMRx\_RPR register is used to enable repetition counting mode. This mode is enabled when the repetition counter value is not equal to 0. In this mode, an overflow event is generated when a counter overflow occurs ( $RPR[7:0]+1$ ). The repetition counter is decremented at each counter overflow. An overflow event is generated when the repetition counter reaches 0. The frequency of the overflow event generation can be adjusted by setting the repetition counter value.

Figure 15-49 OVFIF in upcounting mode and central-aligned mode



### 15.3.3.3 TMR input function

TMR9 has two independent channels that can be configured as input or output each.

As input, each channel input signal is processed as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. The C1INSE bit is used to select TMRx\_CHx as the source of C1IRAW
- CxIRAW goes through digital filter and generates the filtered CxIF signal. The digital filter uses the CxDI bit to program sampling frequency and sampling times.
- CxIF goes through edge detector, and generates the CxIFPx signal after edge selection. The edge selection depends on both CxP and CxCp bits. It is possible to select input rising edge, falling edge or both edges.
- CxIFPx inputs capture signal selector, and outputs the CxIN signal after capture signal selection. The capture signal selection is defined by CxC bits. It is possible to select CxIFPx, CyIFPx or STCI as CxIN source. Of those, CyIFPx ( $x \neq y$ ) is the CyIFPy signal that is from Y channel and processed by channel-x edge detector (for example, C1IFP2 is the C1IFP1 signal that is from channel 1 and processed by channel 2 edge detector). The STCI comes from slave timer controller, and its source is selected by STIS bit.
- CxIN outputs the CxIPS signal that is divided by input channel divider. The divider factor can be defined as No division, /2, /4 or /8, by the CxIDIV bit.

Figure 15-50 Input/output channel 1 main circuit



Figure 15-51 Channel 1 input stage



#### Input mode

In input mode, the TMRx\_CxDT register latches the current counter values after the selected trigger signal is detected, and the capture compare interrupt flag bit (CxIF) is set to 1. An interrupt or DMA request will be generated if the CxIEN bit or CxDEN bit is enabled. If the selected trigger signal is detected when CxIF=1, a capture overflow event is generated. The previous counter value will be overwritten by the current counter value, and the CxRF is set to 1.

To capture the rising edge of C1IN input, follow the procedure below:

- Set C1C=01 in the TMR9\_CM1 register to select the C1IN as channel 1 input

- Set C1IN signal filter bandwidth (CxDF[3: 0])
- Set the active edge of C1IN channel by writing C1P=0 (rising edge) in the TMR9\_CCTRL register
- Program C1IN signal capture frequency divider (C1DIV[1: 0])
- Enable channel 1 input capture (C1EN=1)
- If needed, enable the relevant interrupt or DMA request by setting the C1IEN bit or C1DEN bit in the TMR9\_IDEN register

### PWM input

PWM input mode is applied to channel 1 and 2. To use this mode, both C1IN and C2IN are mapped on the same TMRx\_CHx, and the CxIFPx of either channel 1 or channel 2 must be configured as trigger input and slave mode controller is configured in reset mode.

The PWM input mode can be used to measure the period and duty cycle of the PWM input signal. For example, the user can measure the period and duty cycle of the PWM applied on channel 1 using the following procedures:

- Set C1C=2'b01: select C1IN for C1IFP1
- Set C1P=1'b0, select C1IFP1 rising edge active
- Set C2C=2'b10, select C2IN for C1IFP2
- Set C2P=1'b1, select C1IFP2 falling edge active
- Set STIS=3'b101, select the slave mode timer trigger signal as C1IFP1
- Set SMSEL=3'b100: configure the slave mode controller in reset mode
- Set C1EN=1'b1 and C2EN=1'b1. Enable channel 1 and input capture

After above configuration, the rising edge of channel 1 input signal will trigger the capture and stores the capture value into C1DT register, and it will reset the counter at the same time. The falling edge of the channel 1 input signal triggers the capture and stores the capture value into C2DT register. The period of the channel 1 input signal is calculated through C1DT, and its duty cycle through C2DT.

Figure 15-52 PWM input mode configuration example



Figure 15-53 PWM input mode



#### 15.3.3.4 TMR output function

The TMR output consists of a comparator and an output controller. It is used to program the period, duty cycle and polarity of the output signal.

Figure 15-54 Channel 1 output stage



Figure 15-55 Channel 2 output stage



#### Output mode

Write  $CxC[2: 0] \neq 2'b00$  to configure the channel as output to implement multiple output modes. In this case, the counter value is compared with the value in the  $TMRx\_CxDT$  register, and the intermediate signal  $CxORAW$  is generated according to the output mode selected by  $CxOCTRL[2: 0]$ , which is sent to IO after being processed by the output control circuit. The period of the output signal is configured by the  $TMR9\_PR$  register, while the duty cycle by the  $TMRx\_CxDT$  register.

Output compare modes include:

##### PWM mode A:

Enable PWM mode A by setting  $CxOCTRL=3'b110$ . In upcounting mode,  $C1ORAW$  outputs high when  $TMRx\_C1DT > TMRx\_CVAL$ ; otherwise, it is low. In downcounting mode,  $C1ORAW$  outputs low when  $TMRx\_C1DT < TMRx\_CVAL$ ; otherwise, it is high. Figure 15-56 presents an example of PWM mode A in upcounting mode,  $PR=0x32$ , and  $CxDT$  with different values.

To use PWM mode A, the following procedures are recommended:

- Set PWM period through TMRx\_PR register
- Set PWM duty cycles through TMRx\_CxDT
- Select PWM mode A by setting CxOCTRL=3'b110 in the TMRx\_CM1/CM2 register
- Set counting frequency through TMRx\_DIV register
- Select counting mode by setting the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register
- Select output polarity through the CxP and CxCp bits in the TMRx\_CCTRL register
- Enable channel output through the CxEN and CxCEN bits in the TMRx\_CCTRL register
- Enable TMRx output through the OEN bit in the TMRx\_BRK register
- Configure GPIOs corresponding to TMR output channels as multiplexed mode
- Enable TMRx to start counting through the TMREN bit in the TMRx\_CTRL1 register.

Figure 15-56 PWM mode A in upcounting mode



#### PWM mode B:

Enable PWM mode B by setting CxOCTRL=3'b111. In upcounting mode, C1ORAW outputs low when TMRx\_C1DT>TMRx\_CVAL; otherwise, it is high. In downcounting mode, C1ORAW outputs high when TMRx\_C1DT<TMRx\_CVAL; otherwise, it is low.

#### Forced output mode:

Enable forced output mode by setting CxOCTRL=2'b100/101. In this case, the CxORAW is forced to be the programmed level, regardless of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.

#### Output compare mode:

Enable output compare mode by setting CxOCTRL=3'b001/010/011. In this case, when the counter value matches the value of the CxDT register, the CxORAW is forced high (CxOCTRL=3'b001), low (CxOCTRL=3'b010) or toggling (CxOCTRL=3'b011). Figure 15-57 presents an example of output compare mode, C1DT=0x3. When the counter value is 0x3, C1OUT toggles.

Figure 15-57 C1ORAW toggles when counter value matches C1DT value



**One-pulse mode:**

This is a particular case of PWM mode. Enable one-pulse by setting OCMEN=1. In this mode, the comparison match is performed in the current counting period. The TMREN bit is cleared as soon as the current counting is completed. Therefore, only one pulse is output. When in upcounting mode, the configuration must follow the rule: CVAL<CxDT<PR; in downcounting mode, CVAL>CxDT is required. Figure 15-58 presents an example of PWM B in upcounting mode & one-pulse mode. The counter counts a single cycle, and only a single pulse is output during this cycle.

Figure 15-58 One-pulse mode

**Fast output mode:**

Enable this mode by setting CxOEN=1. If enabled, the CxORAW signal will not change when the counter value matches the CxDT, but change at the beginning of the current counting period. In other words, the comparison result is advanced, so the comparison result between the counter value and the TMRx\_CxDT register will determine the level of CxORAW in advance.

Figure 15-59 Upcounting mode and PWM mode A

**Master mode timer event output**

When TMR is used as a master timer, one of the following source of signals can be selected as TRGOUT output to a slave mode timer. This is done by setting the PTOS bit in the TMRx\_CTRL2 register.

- PTOS=3'b000, TRGOUT output software overflow event (OVFSWTR bit in TMRx\_SWEVT register) or reset event
- PTOS=3'b001, TRGOUT output counter enable
- PTOS=3'b010, TRGOUT output counter overflow event
- PTOS=3'b011, TRGOUT output capture and compare event (C1DT)

- PTOS=3'b100, TRGOUT output C1ORAW
- PTOS=3'b101, TRGOUT output C2ORAW

#### Dead-time insertion

TMR9 channel 1 has a reverse channel output. This function is enabled by the CxCEN bit and its polarity is selected by CxCP. Refer to Table 15-15 for more information about the output state of CxOUT and CxCOUT.

The dead-time is activated when switching to IDLEF state (OEN falling down to 0).

Setting both CxEN and CxCEN bits, and using DTC[7:0] bit to insert dead-time of different durations. After the dead-time insertion, the rising edge of the CxOUT is delayed compared to the rising edge of the reference signal; the rising edge of the CxCOUT is delayed compared to the falling edge of the reference signal.

If the delay is greater than the width of the active output, C1OUT and C1COUT will not generate corresponding pulses. Therefore, the dead-time should be less than the width of the active output.

[Figure 15-60](#) gives an example of dead-time insertion when CxP=0, CxCP=0, OEN=1, CxEN=1 and CxCEN=1.

Figure 15-60 Complementary output with dead-time insertion



#### 15.3.3.5 TMR brake function

When the brake function is enabled (BRKEN=1), the CxOUT and CxCOUT are jointly controlled by OEN, FCSODIS, FCSOEN, CxIOS and CxCIOS. But, CxOUT and CxCOUT cannot be set both to active level at the same time. Please refer to 15-9 for more details.

The brake source can be a brake input pin or a clock failure event. The polarity is controlled by BRKV bit.

When a brake event occurs, there are the following actions:

- The OEN bit is cleared asynchronously, and the channel output state is selected by setting the FCSODIS bit. This function works even if the MCU oscillator is off.
- Once OEN=0, the channel output level is defined by the CxIOS bit. If FCSODIS=0, the timer output is disabled; otherwise, the output enable remains high.
- When complementary outputs are used:
  - The outputs are first put in reset state, that is, inactive state (depending on the polarity). This is done asynchronously so that it works even if no clock is provided to the timer.
  - If the timer clock is still active, then the dead-time generator is activated. The CxIOS and CxCIOS bits are used to program the level after dead-time. Even in this case, the CxIOS and CxCIOS cannot be driven to their active level at the same time.

*Note: The dead-time duration is usually longer than usual (around 2 tmr\_clk clock cycles) due to OEN synchronization logic.*

- If FCSODIS=0, the timer releases the enable output; otherwise, it keeps the enable output; the enable output becomes high as soon as one of the CxEN and CxCEN bits becomes high.

- If the brake interrupt or DMA request is enabled, the brake status flag is set, and a brake interrupt or DMA request can be generated.
- If AOEN=1, the OEN bit is automatically set again at the next overflow event.

*Note: When the brake input is active, the OEN cannot be set, nor the status flag, BRKIF can be cleared.*

Figure 15-61 TMR output control



Figure 15-62 Example of TMR brake function



### 15.3.3.6 TMR synchronization

The master and slave timers are linked together internally for timer synchronization. Master mode timer is selected by setting the PTOS[2: 0] bit; Slave timer is selected by setting the SMSEL[2: 0] bit.

Slave modes include:

#### Slave mode: Reset mode

The counter and its prescaler can be reset by a selected trigger signal. An overflow event can be generated when OVFS=0.

Figure 15-63 Example of reset mode

**Slave mode: Suspend mode**

In this mode, the counter is controlled by a selected trigger input. The counter starts counting when the trigger input is high and stops as soon as the trigger input is low.

Figure 15-64 Example of suspend mode

**Slave mode: Trigger mode**

The counter can start counting on the rising edge of a selected trigger input (TMR\_EN=1)

Figure 15-65 Example of trigger mode



See [Chapter 15.2.3.5](#) for more information about timer synchronization.

### 15.3.3.7 TMR DMA

TMR has the following events for DMA transfer request: overflow event DMA request, trigger event DMA request, Hall sensor DMA request and channel event DMA request. It is possible to enable DMA request by setting the TMRx\_IDEN register. Once enabled, upon an event generated, a DMA request is triggered and output to the DMA peripheral.

#### TMR DMA Burst feature

TMR also supports TMR DMA Burst feature. Thanks to this feature, DMA can be triggered to rewrite multiple TMR consecutive registers by enabling a certain DMA request through the TMRx\_IDEN register.

As an overflow event to trigger TMR DMA Burst as an example:

- Enable overflow event to trigger DMA request using the OVFDEN bit in the TMRx\_IDEN register
- Configure Burst transfer times using the DTB bit in the TMRx\_DMACTRL register
- Configure the start address of Burst transfer using the ADDR bit in the TMRx\_DMACTRL register
- Enable counter

After the above-mentioned configurations, here is the whole process of TMR DMA Burst transfer:

Upon an overflow event, the TMR will send a DMA request to the DMA peripheral. Then the DMA writes the data into the TMRx\_DMADT register as requested. Inside TMR, the DMADT bit data is written into the start address register of Burst transfer and an ACK single is sent to TMR. After receiving this ACK, the TMR clears the current DMA request; when the Burst transfer is detected by the TMR not to complete fully, a new overflow event for DMA request is released to the DMA so that the DMA writes the requested data into the TMRx\_DMADT again. In this case, inside tmr, the DMADT register data is written into the Burst transfer start address + 0x4 address register, and a new ACK is sent to TMR, and so on, and so on, until the last operation of Burst transfer. When a full Burst transfer is complete, the REQ for overflow event DMA request would not be set any more until the next overflow event.

*Note: when using TMR DMA Burst feature, an empty register is prohibited and the TMRx\_DMACTRL as well as TMRx\_DMADT registers should not be available during the period from the start address to the end address.*

### 15.3.3.8 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the TMRx counter stops counting by setting the TMR9\_PAUSE in the DEBUG module.

### 15.3.4 TMR9 registers

Table 15-8 TMR9 register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| TMR9_CTRL1  | 0x00   | 0x0000 0000 |
| TMR9_CTRL2  | 0x04   | 0x0000 0000 |
| TMR9_STCTRL | 0x08   | 0x0000 0000 |
| TMR9_IDEN   | 0x0C   | 0x0000 0000 |
| TMR9ISTS    | 0x10   | 0x0000 0000 |
| TMR9_SWEVT  | 0x14   | 0x0000 0000 |
| TMR9_CM1    | 0x18   | 0x0000 0000 |
| TMR9_CCTRL  | 0x20   | 0x0000 0000 |
| TMR9_CVAL   | 0x24   | 0x0000 0000 |
| TMR9_DIV    | 0x28   | 0x0000 0000 |
| TMR9_PR     | 0x2C   | 0x0000 FFFF |
| TMR9_RPR    | 0x30   | 0x0000 0000 |
| TMR9_C1DT   | 0x34   | 0x0000 0000 |
| TMR9_C2DT   | 0x38   | 0x0000 0000 |
| TMR9_BRK    | 0x44   | 0x0000 0000 |

|              |      |             |
|--------------|------|-------------|
| TMR9_DMACTRL | 0x48 | 0x0000 0000 |
| TMR9_DMADT   | 0x4C | 0x0000 0000 |

### 15.3.4.1 TMR9 control register 1 (TMR9\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x00 0000   | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | Clock divider<br>This field is used to define the division ratio between digital filter sampling frequency ( $f_{DTS}$ ) and the timer clock frequency ( $f_{CK\_INT}$ ). It is also used to set the division ratio between dead time base ( $T_{DTS}$ ) and timer clock period ( $T_{CK\_INT}$ )<br>00: No division, $f_{DTS}=f_{CK\_INT}$<br>01: Divided by 2, $f_{DTS}=f_{CK\_INT}/2$<br>10: Divided by 4, $f_{DTS}=f_{CK\_INT}/4$<br>11: Reserved                                                         |
| Bit 7      | PRBEN    | 0x0         | rw   | Period buffer enable<br>0: Period buffer is disabled<br>1: Period buffer is enabled                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 6: 5   | TWCMSEL  | 0x0         | resd | Two-way counting mode selection<br>00: One-way counting mode, depending on the OWCDIR bit<br>01: Two-way counting mode 1. The counter counts up and down alternately, the CxIF bit is set only when the counter is counting down<br>10: Two-way counting mode 2. The counter counts up and down alternately, the CxIF bit is set only when the counter is counting up<br>11: Two-way counting mode 3. The counter counts up and down alternately, the CxIF bit is set when the counter is counting up or down |
| Bit 4      | OWCDIR   | 0x0         | rw   | One-way count direction<br>0: Up<br>1: Down                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 3      | OCMEN    | 0x0         | rw   | One cycle mode enable<br>This bit is used to select whether to stop counting at an overflow event<br>0: The counter does not stop at an overflow event<br>1: The counter stops at an overflow event                                                                                                                                                                                                                                                                                                           |
| Bit 2      | OVFS     | 0x0         | rw   | Overflow event source<br>This bit is used to select overflow event or DMA request sources.<br>0: Counter overflow, setting the OVFSWTR bit or overflow event generated by slave timer controller<br>1: Only counter overflow generates an overflow event                                                                                                                                                                                                                                                      |
| Bit 1      | OVFEN    | 0x0         | rw   | Overflow event enable<br>0: Enabled<br>1: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 0      | TMREN    | 0x0         | rw   | TMR enable<br>0: Enabled<br>1: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 15.3.4.2 TMR9 control register 2 (TMR9\_CTRL2)

| Bit        | Name     | Reset value | Type | Description                                                                                                          |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                               |
| Bit 11     | C2CIOS   | 0x0         | rw   | Channel 2 complementary idle output state                                                                            |
| Bit 10     | C2IOS    | 0x0         | rw   | Channel 2 idle output state                                                                                          |
| Bit 9      | C1CIOS   | 0x0         | rw   | Channel 1 complementary idle output state<br>Output disabled (OEN= 0) after dead-time:<br>0: C1OUTL=0<br>1: C1OUTL=1 |

|          |          |     |      |                                                                                                                                                                                                                                                                                              |
|----------|----------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 8    | C1IOS    | 0x0 | rw   | Channel 1 idle output state<br>Output disabled (OEN = 0) after dead-time:<br>0: C1OUT=0<br>1: C1OUT=1                                                                                                                                                                                        |
| Bit 7    | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                       |
| Bit 6: 4 | PTOS     | 0x0 | rw   | Master TMR output selection<br>This field is used to select the TMRx signal sent to the slave timer.<br>000: Software overflow or Reset<br>001: Enable<br>010: Overflow<br>011: Compare pulse (C1DT)<br>100: C1ORAW signal<br>101: C2ORAW signal<br>110: C3ORAW signal<br>111: C4ORAW signal |
| Bit 3    | DRS      | 0x0 | rw   | DMA request source<br>0: Capture/compare event<br>1: Overflow event                                                                                                                                                                                                                          |
| Bit 2    | CCFS     | 0x0 | rw   | Channel control bit flash selection<br>This bit only acts on channels that have complementary output. If the channel control bits are buffered:<br>0: Control bits are updated by setting the HALL bit<br>1: Control bits are updated by setting the HALL bit or a rising edge on TRGIN.     |
| Bit 1    | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                       |
| Bit 0    | CBCTRL   | 0x0 | rw   | Channel buffer control<br>This bit acts on channels that have complementary output.<br>0: CxEN, CxCEN and CxOCTRL bits are not buffered.<br>1: CxEN, CxCEN and CxOCTRL bits are buffered.                                                                                                    |

#### 15.3.4.3 TMR9 slave timer control register (TMR9\_STCTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 7     | STS      | 0x0         | rw   | Subordinate TMR synchronization<br>If enabled, master and slave timer can be synchronized.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                               |
| Bit 6: 4  | STIS     | 0x0         | rw   | Subordinate TMR input selection<br>This field is used to select the subordinate TMR input.<br>000: Internal selection 0 (IS0)<br>001: Internal selection 1 (IS1)<br>010: Internal selection 2 (IS2)<br>011: Internal selection 3 (IS3)<br>100: C1IRAW input detector (C1INC)<br>101: Filtered input 1 (C1IF1)<br>110: Filtered input 2 (C1IF2)<br>111: External input (EXT)<br>Please refer to Table 15-7 for more information on ISx for each timer. |
| Bit 3     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 2: 0  | SMSEL    | 0x0         | rw   | Subordinate TMR mode selection<br>000: Slave mode is disabled<br>001: Reserved<br>010: Reserved<br>011: Reserved<br>100: Reset mode — Rising edge of the TRGIN input reinitializes the counter<br>101: Suspend mode — The counter starts counting when the TRGIN is high<br>110: Trigger mode — A trigger event is generated at the rising edge of the TRGIN input                                                                                    |

111: External clock mode A — Rising edge of the TRGIN input clocks the counter  
 Note: Please refer to count mode section for the details on encoder mode A/B/C.

#### 15.3.4.4 TMR9 DMA/interrupt enable register (TMR9\_IDEN)

| Bit        | Name     | Reset value | Type | Description                                                    |
|------------|----------|-------------|------|----------------------------------------------------------------|
| Bit 31:15  | Reserved | 0x0 0000    | resd | Kept at default value.                                         |
| Bit 14     | TDEN     | 0x0         | rw   | Trigger DMA request enable<br>0: Disabled<br>1: Enabled        |
| Bit 13     | HALLDE   | 0x0         | rw   | HALL DMA request enable<br>0: Disabled<br>1: Enabled           |
| Bit 12: 11 | Reserved | 0x0         | resd | Kept at default value.                                         |
| Bit 10     | C2DEN    | 0x0         | rw   | Channel 2 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 9      | C1DEN    | 0x0         | rw   | Channel 1 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 8      | OVFDEN   | 0x0         | rw   | Overflow event DMA request enable<br>0: Disabled<br>1: Enabled |
| Bit 7      | BRKIE    | 0x0         | rw   | Brake interrupt enable<br>0: Disabled<br>1: Enabled            |
| Bit 6      | TIEN     | 0x0         | rw   | Trigger interrupt enable<br>0: Disabled<br>1: Enabled          |
| Bit 5      | HALLIEN  | 0x0         | rw   | HALL interrupt enable<br>0: Disabled<br>1: Enabled             |
| Bit 4: 3   | Reserved | 0x0         | resd | Kept at default value.                                         |
| Bit 2      | C2IEN    | 0x0         | rw   | Channel 2 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 1      | C1IEN    | 0x0         | rw   | Channel 1 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 0      | OVFIEN   | 0x0         | rw   | Overflow interrupt enable<br>0: Disabled<br>1: Enabled         |

#### 15.3.4.5 TMR9 interrupt status register (TMR9ISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 11 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                       |
| Bit 10     | C2RF     | 0x0         | rw0c | Channel 2 recapture flag<br>Please refer to C1RF description.                                                                                                                                                |
| Bit 9      | C1RF     | 0x0         | rw0c | Channel 1 recapture flag<br>This bit indicates whether a recapture is detected when C1IF=1. This bit is set by hardware, and cleared by writing "0".<br>0: No capture is detected<br>1: Capture is detected. |
| Bit 8      | Reserved | 0x0         | resd | Default value                                                                                                                                                                                                |
| Bit 7      | BRKIF    | 0x0         | rw0c | Brake interrupt flag<br>This bit indicates whether the brake input is active or not.<br>It is set by hardware and cleared by writing "0"<br>0: Inactive level<br>1: Active level                             |
| Bit 6      | TRGIF    | 0x0         | rw0c | Trigger interrupt flag                                                                                                                                                                                       |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|----------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | This bit is set by hardware on a trigger event. It is cleared by writing "0".<br>0: No trigger event occurs<br>1: Trigger event is generated.<br>Trigger event: an active edge is detected on TRGIN input, or any edge in suspend mode.                                                                                                                                                                                                              |
| Bit 5    | HALLIF   | 0x0 | rw0c | HALL interrupt flag<br>This bit is set by hardware on HALL event. It is cleared by writing "0".<br>0: No Hall event occurs.<br>1: Hall event is detected.<br>HALL even: CxEN, CxCEN and CxOCTRL are updated.                                                                                                                                                                                                                                         |
| Bit 4: 3 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 2    | C2IF     | 0x0 | rw0c | Channel 2 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 1    | C1IF     | 0x0 | rw0c | Channel 1 interrupt flag<br>If the channel 1 is configured as input mode:<br>This bit is set by hardware on a capture event. It is cleared by software or read access to the TMRx_C1DT<br>0: No capture event occurs<br>1: Capture event is generated<br>If the channel 1 is configured as output mode:<br>This bit is set by hardware on a compare event. It is cleared by software.<br>0: No compare event occurs<br>1: Compare event is generated |
| Bit 0    | OVFIF    | 0x0 | rw0c | Overflow interrupt flag<br>This bit is set by hardware on an overflow event. It is cleared by software.<br>0: No overflow event occurs<br>1: Overflow event is generated. If OVFEN=0 and OVFS=0 in the TMRx_CTRL1 register:<br>– An overflow event is generated when OVFG= 1 in the TMRx_SWEVE register;<br>– An overflow event is generated when the counter CVAL is reinitialized by a trigger event.                                              |

#### 15.3.4.6 TMR9 software event register (TMR9\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                         |
| Bit 7     | BRKSWTR  | 0x0         | wo   | Brake event triggered by software<br>This bit is set by software to generate a brake event.<br>0: No effect<br>1: Generate a brake event.                                                                      |
| Bit 6     | TRGSWTR  | 0x0         | rw   | Trigger event triggered by software<br>This bit is set by software to generate a trigger event.<br>0: No effect<br>1: Generate a trigger event.                                                                |
| Bit 5     | HALLSWTR | 0x0         | wo   | HALL event triggered by software<br>This bit is set by software to generate a HALL event.<br>0: No effect<br>1: Generate a HALL event.<br>Note: This bit acts only on channels that have complementary output. |
| Bit 4: 3  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                     |
| Bit 2     | C2SWTR   | 0x0         | wo   | Channel 2 event triggered by software<br>Please refer to C1SWTR description                                                                                                                                    |
| Bit 1     | C1SWTR   | 0x0         | wo   | Channel 1 event triggered by software<br>This bit is set by software to generate a channel 1 event.<br>0: No effect<br>1: Generate a channel 1 event.                                                          |
| Bit 0     | OVFSWTR  | 0x0         | wo   | Overflow event triggered by software<br>This bit is set by software to generate an overflow event.<br>0: No effect                                                                                             |

---

 1: Generate an overflow event.
 

---

### 15.3.4.7 TMR9 channel mode register 1 (TMR9\_CM1)

The channel can be used in input (capture mode) or output (compare mode). The direction of a channel is defined by the corresponding CxC bit. All the other bits of this register have different functions in input and output modes. The CxOx describes its function in output mode when the channel is in output mode, while the Cxlx describes its function in output mode when the channel is in input mode. Attention must be given to the fact that the same bit can have different functions in input mode and output mode.

#### Output compare mode:

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:15  | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 14: 12 | C2OCTRL  | 0x0         | rw   | Channel 2 output control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 11     | C2OBEN   | 0x0         | rw   | Channel 2 output buffer enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 10     | C2OIEN   | 0x0         | rw   | Channel 2 output enable immediately                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|            |          |             |      | Channel 2 configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            |          |             |      | This field is used to define the direction of the channel 2 (input or output), and the selection of input pin when C2EN='0':                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 9: 8   | C2C      | 0x0         | rw   | 00: Output<br>01: Input, C2IN is mapped on C2IFP2<br>10: Input, C2IN is mapped on C1IFP2<br>11: Input, C2IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 7      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|            |          |             |      | Channel 1 output control<br>This field defines the behavior of the original signal C1ORAW.<br>000: Disconnected. C1ORAW is disconnected from C1OUT;<br>001: C1ORAW is high when TMRx_CVAL=TMRx_C1DT<br>010: C1ORAW is low when TMRx_CVAL=TMRx_C1DT<br>011: Switch C1ORAW level when TMRx_CVAL=TMRx_C1DT<br>100: C1ORAW is forced low<br>101: C1ORAW is forced high.<br>110: PWM mode A<br>— OWCDIR=0, C1ORAW is high once TMRx_C1DT>TMRx_CVAL, else low;<br>— OWCDIR=1, C1ORAW is low once TMRx_C1DT<TMRx_CVAL, else high;<br>111: PWM mode B<br>— OWCDIR=0, C1ORAW is low once TMRx_C1DT>TMRx_CVAL, else high;<br>— OWCDIR=1, C1ORAW is high once TMRx_C1DT<TMRx_CVAL, else low.<br><i>Note: In the configurations other than 000', the C1OUT is connected to C1ORAW. The C1OUT output level is not only subject to the changes of C1ORAW, but also the output polarity set by CCTRL.</i> |
| Bit 6: 4   | C1OCTRL  | 0x0         | rw   | Channel 1 output buffer enable<br>0: Buffer function of TMRx_C1DT is disabled. The new value written to the TMRx_C1DT takes effect immediately.<br>1: Buffer function of TMRx_C1DT is enabled. The value to be written to the TMRx_C1DT is stored in the buffer register, and can be sent to the TMRx_C1DT register only on an overflow event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3      | C1OBEN   | 0x0         | rw   | Channel 1 output enable immediately                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 2      | C1OIEN   | 0x0         | rw   | In PWM mode A or B, this bit is used to accelerate the channel 1 output's response to the trigger event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|            |          |             |      | 0: Need to compare the CVAL with C1DT before generating an output<br>1: No need to compare the CVAL and C1DT. An output is generated immediately when a trigger event occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |             |      | Channel 1 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 1: 0   | C1C      | 0x0         | rw   | 00: Output<br>01: Input, C1IN is mapped on C1IFP1<br>10: Input, C1IN is mapped on C2IFP1<br>11: Input, C1IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |          |             |      | <b>Input capture mode:</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 31:16  | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 15: 12 | C2DF     | 0x0         | rw   | Channel 2 digital filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 11: 10 | C2IDIV   | 0x0         | rw   | Channel 2 input divider                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|            |          |             |      | Channel 2 configuration<br>This field is used to define the direction of the channel 2 (input or output), and the selection of input pin when C2EN='0':                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 9: 8   | C2C      | 0x0         | rw   | 00: Output<br>01: Input, C2IN is mapped on C2IFP2<br>10: Input, C2IN is mapped on C1IFP2<br>11: Input, C2IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |          |             |      | Channel 1 digital filter<br>This field defines the digital filter of the channel 1. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 7: 4   | C1DF     | 0x0         | rw   | 0000: No filter, sampling is done at $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
|            |          |             |      | Channel 1 input divider<br>This field defines Channel 1 input divider.<br>00: No divider. An input capture is generated at each active edge.<br>01: An input compare is generated every 2 active edges<br>10: An input compare is generated every 4 active edges<br>11: An input compare is generated every 8 active edges<br>Note: the divider is reset once C1EN='0'                                                                                                                                                                                                                                                                                                                                           |
| Bit 1: 0   | C1C      | 0x0         | rw   | Channel 1 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

00: Output  
 01: Input, C1IN is mapped on C1IFP1  
 10: Input, C1IN is mapped on C2IFP1  
 11: Input, C1IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.

### 15.3.4.8 TMR9 channel control register (TMR9\_CCTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 7     | C2CP     | 0x0         | rw   | Channel 2 complementary polarity<br>Please refer to C1P description.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 6     | C2CEN    | 0x0         | rw   | Channel 2 complementary enable<br>Please refer to C1EN description.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 5     | C2P      | 0x0         | rw   | Channel 2 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 4     | C2EN     | 0x0         | rw   | Channel 2 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 3     | C1CP     | 0x0         | rw   | Channel 1 complementary polarity<br>0: C1COUT is active high.<br>1: C1COUT is active low.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 2     | C1CEN    | 0x0         | rw   | Channel 1 complementary enable<br>0: Output is disabled.<br>1: Output is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 1     | C1P      | 0x0         | rw   | Channel 1 polarity<br>When the channel 1 is configured as output mode:<br>0: C1OUT is active high<br>1: C1OUT is active low<br>When the channel 1 is configured as input mode:<br>00: C1IN active edge is on its rising edge. When used as external trigger, C1IN is not inverted.<br>01: C1IN active edge is on its falling edge. When used as external trigger, C1IN is inverted.<br>10: Reserved<br>11: C1IN active edge is on its rising edge and falling edge. When used as external trigger, C1IN is not inverted. |
| Bit0      | C1EN     | 0x0         | rw   | Channel 1 enable<br>0: Input or output is disabled<br>1: Input or output is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Table 15-9 Complementary output channel CxOUT and CxCOUT control bits with brake function

|         |             | Control bit |          |           | Output state <sup>(1)</sup>                                                       |                                                                                                                                                                    |                                                                               |
|---------|-------------|-------------|----------|-----------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| OEN bit | FCSODIS bit | FCSOEN bit  | CxEN bit | CxCEN bit | CxOUT output state                                                                | CxCOUT output state                                                                                                                                                |                                                                               |
| 1       | X           | 0           | 0        | 0         | Output disabled<br>(no driven by the timer)<br>CxOUT=0, Cx_EN=0                   | Output disabled<br>(no driven by the timer)<br>CxOUT=0, CxCEN=0                                                                                                    |                                                                               |
|         |             |             | 0        | 0         | 1                                                                                 | CxORAW + polarity,<br>CxOUT= CxORAW xor<br>CxCP, CxCEN=1                                                                                                           |                                                                               |
|         |             |             | 0        | 1         | 0                                                                                 | CxORAW+ polarity<br>CxOUT= CxORAW xor CxP,<br>Cx_EN=1                                                                                                              |                                                                               |
|         |             |             | 0        | 1         | 1                                                                                 | CxORAW+polarity+dead-<br>time,<br>Cx_EN=1                                                                                                                          | CxORAW<br>inverted+polarity+dead-<br>time,<br>CxCEN=1                         |
|         |             | 1           | 1        | 0         | Output disabled<br>(no driven by the timer)<br>CxOUT=CxP, Cx_EN=0                 | Output disabled<br>(no driven by the timer)<br>CxOUT=CxP,<br>CxEN=0                                                                                                |                                                                               |
|         |             |             | 1        | 0         | 1                                                                                 | Off-state<br>(Output enabled with<br>inactive level)<br>CxOUT=CxP, Cx_EN=1                                                                                         | CxORAW + polarity,<br>CxOUT= CxORAW xor<br>CxCP, CxCEN=1                      |
|         |             |             | 1        | 1         | 0                                                                                 | CxORAW + polarity,<br>CxOUT= CxORAW xor CxP,<br>Cx_EN=1                                                                                                            | Off-state<br>(Output enabled with<br>inactive level)<br>CxOUT=CxP,<br>CxCEN=1 |
|         |             |             | 1        | 1         | 1                                                                                 | CxORAW+ polarity+dead-<br>time, Cx_EN=1                                                                                                                            | CxORAW<br>inverted+polarity+dead-<br>time,<br>CxCEN=1                         |
|         |             | 0           | 0        | 0         | Output disabled<br>(the corresponding IO disconnected from timer, IO<br>floating) |                                                                                                                                                                    |                                                                               |
|         |             |             | 0        | 0         | 1                                                                                 | Asynchronously: CxOUT=CxP, Cx_EN=0,<br>CxOUT=CxP, CxCEN=0;                                                                                                         |                                                                               |
|         |             |             | 0        | 1         | 0                                                                                 | If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level. |                                                                               |
|         |             |             | 0        | 1         | 1                                                                                 | CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level.                                                |                                                                               |
|         |             |             | 1        | 0         | 0                                                                                 | CxEN=CxCEN=0: output disabled (the corresponding<br>IO disconnected from timer, IO floating)                                                                       |                                                                               |
|         |             |             | 1        | 0         | 1                                                                                 | Other: Off-state (the corresponding channel outputs<br>inactive level)                                                                                             |                                                                               |
|         |             |             | 1        | 1         | 0                                                                                 | Asynchronously: CxOUT =CxP, Cx_EN=1,<br>CxOUT=CxP, CxCEN=1;                                                                                                        |                                                                               |
|         |             |             | 1        | 1         | 1                                                                                 | If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level. |                                                                               |

Note: If the two outputs of a channel are not used (CxEN = CxCEN = 0), CxIOS, CxCIOS, CxP and CxCP must be cleared.

Note: The state of the external I/O pins connected to the complementary CxOUT and CxCOUT channels depends on the CxOUT and CxCOUT channel state and the GPIO and the IOMUX registers.

### 15.3.4.9 TMR9 counter value register (TMR9\_CVAL)

| Bit        | Name     | Reset value | Type | Description            |
|------------|----------|-------------|------|------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value. |
| Bit 15: 0  | CVAL     | 0x0000      | rw   | Counter value          |

### 15.3.4.10 TMR9 division value register (TMR9\_DIV)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                     |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                          |
| Bit 15: 0  | DIV      | 0x0000      | rw   | Divider value<br>The counter clock frequency $f_{CK\_CNT} = f_{TMR\_CLK} / (\text{DIV}[15:0]+1)$ .<br>The value of this register is transferred to the actual prescaler register when an overflow event occurs. |

### 15.3.4.11 TMR9 period register (TMR9\_PR)

| Bit        | Name     | Reset value | Type | Description                                                                                                            |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                 |
| Bit 15: 0  | PR       | 0xFFFF      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

### 15.3.4.12 TMR9 repetition period register (TMR9\_RPR)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                              |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                   |
| Bit 7: 0  | RPR      | 0x0000      | rw   | Repetition of period value<br>This field is used to reduce the generation rate of overflow events. An overflow event is generated when the repetition counter reaches 0. |

### 15.3.4.13 TMR9 channel 1 data register (TMR9\_C1DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 15: 0  | C1DT     | 0x0000      | rw   | Channel 1 data register<br>When the channel 1 is configured as input mode:<br>The C1DT is the CVAL value stored by the last channel 1 input event (C1IN).<br><br>When the channel 1 is configured as output mode:<br>C1DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C1OBEN bit, and the corresponding output is generated on C1OUT as configured. |

### 15.3.4.14 TMR9 channel 2 data register (TMR9\_C2DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 15: 0  | C2DT     | 0x0000      | rw   | Channel 2 data register<br>When the channel 2 is configured as input mode:<br>The C2DT is the CVAL value stored by the last channel 2 input event (C2IN).<br><br>When the channel 2 is configured as output mode:<br>C2DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C2OBEN bit, and the corresponding output is generated on C2OUT as configured. |

### 15.3.4.15 TMR9 break register (TMR9\_BRK)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            |          |             |      | Brake input filter<br>This field is used to set the filter for brake input. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output.<br>0000: No filter, sampling is done at $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
| Bit 19: 16 | BKF      | 0x0         | rw   | Output enable<br>This bit acts on the channels as output. It is used to enable CxOUT and CxCOUT outputs.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 15     | OEN      | 0x0         | rw   | Automatic output enable<br>OEN is set automatically at an overflow event.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 14     | AOEN     | 0x0         | rw   | Brake input validity<br>This bit is used to select the active level of a brake input.<br>0: Brake input is active low.<br>1: Brake input is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 13     | BRKV     | 0x0         | rw   | Brake enable<br>This bit is used to enable brake input.<br>0: Brake input is disabled.<br>1: Brake input is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 11     | FCSOEN   | 0x0         | rw   | Frozen channel status when holistic output enable<br>This bit acts on the channels that have complementary output. It is used to set the channel state when the timer is inactive and OEN=1.<br>0: CxOUT/CxCOUT outputs are disabled.<br>1: CxOUT/CxCOUT outputs are enabled. Output inactive level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 10     | FCSODIS  | 0x0         | rw   | Frozen channel status when holistic output disable<br>This bit acts on the channels that have complementary output. It is used to set the channel state when the timer is inactive and OEN=0.<br>0: CxOUT/CxCOUT outputs are disabled.<br>1: CxOUT/CxCOUT outputs are enabled. Output idle level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 9: 8   | WPC      | 0x0         | rw   | Write protection configuration<br>This field is used to enable write protection.<br>00: Write protection is OFF.<br>01: Write protection level 3, and the following bits are write protected:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|          |     |      |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|-----|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |     |      |    | TMRx_BRK: BRKF, DTC, BRKEN, BRKV and AOEN<br>TMRx_CTRL2: CxIOS and CxCIOS<br>10: Write protection level 2. The following bits and all bits in level 3 are write protected:<br>TMRx_CCTRL: CxP and CxCP<br>TMRx_BRK: FCSODIS and FCSOEN<br>11: Write protection level 1. The following bits and all bits in level 2 are write protected:<br>TMR9_CM1: CxOCTRL and CxOBEN<br>Note: Once WPC>0, its content remains frozen until the next system reset. |
| Bit 7: 0 | DTC | 0x00 | rw | Dead-time configuration<br>This field defines the duration of the dead-time insertion.<br>The 3-bit MSB of DTC[7: 0] is used for function selection:<br>0xx: DT = DTC [7: 0] * TDTS<br>10x: DT = (64+ DTC [5: 0]) * TDTS * 2<br>110: DT = (32+ DTC [4: 0]) * TDTS * 8<br>111: DT = (32+ DTC [4: 0]) * TDTS * 16                                                                                                                                      |

Note: BRKF, AOEN, BRKV, BRKEN, FCSODIS, FCSOEN and DTC[7: 0] can be write-protected. But these bits must be configured before the first write access to the TMR9\_BRK register.

#### 15.3.4.16 TMR9 DMA control register (TMR9\_DMACTL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                       |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:13 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                            |
| Bit 12:8  | DTB      | 0x00        | rw   | DMA transfer bytes<br>This field defines the number of DMA transfers:<br>00000: 1 byte      00001: 2 bytes<br>00010: 3 bytes      00011: 4 bytes<br>.....<br>10000: 17 bytes      10001: 18 bytes |
| Bit 7:5   | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                            |
| Bit 4: 0  | ADDR     | 0x00        | rw   | DMA transfer address offset<br>ADDR is defined as an offset starting from the address of the TMRx_CTRL1 register:<br>00000: TMRx_CTRL1<br>00001: TMRx_CTRL2<br>00010: TMRx_STCTRL<br>.....        |

#### 15.3.4.17 TMR9 DMA data register (TMR9\_DMADT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                   |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                        |
| Bit 15: 0 | DMADT    | 0x0000      | rw   | DMA data register<br>A write/read operation to the DMADT register accesses any TMR register located at the following address:<br>TMRx peripheral address + ADDR*4 to TMRx peripheral address + ADDR*4 + DTB*4 |

## 15.4 General-purpose timers (TMR10/11/13/14)

### 15.4.1 TMRx introduction

The general-purpose timers (TMR10/11/13/14) consist of a 16-bit upcounter. They have a capture/compare register, and an independent channel for dead-time insertion, input capture and programmable PWM output.

### 15.4.2 TMRx main features

- 16-bit upcounter, and 8-bit repetition counter
- One independent channel for input capture, output compare, PWM generation, one-pulse mode output and dead-time insertion
- One independent channel with complementary output
- TMR brake function
- Synchronization control between master and slave timers
- Interrupt/DMA generation at overflow event, brake signal input and channel events
- Support TMR burst DMA transfer

Figure 15-66 TMR10/11/13/14 block diagram



### 15.4.3 TMRx functional overview

#### 15.4.3.1 Counting clock

The count clock of TMR10/11/13/14 can be provided by the internal clock (CK\_INT).

Figure 15-67 Counting clock



#### Internal clock (CK\_INT)

By default, the CK\_INT, which is divided by the prescaler, is used to drive the counter to start counting. When TMR's APB clock prescaler factor is 1, the CK\_INT frequency is equal to that of the APB; otherwise, it doubles the APB clock frequency.

- Select counting mode by setting the TWCSEL[1:0] in TMRx\_CTRL1 register. If a unidirectional aligned counting mode is selected, there is a need to select counting direction through the OWCDIR in TMRx\_CTRL1 register.
- Set counting frequency through TMRx\_DIV register
- Set counting cycles through TMRx\_PR register
- Enable a counter by setting the TMREN bit in the TMRx\_CTRL1 register

Figure 15-68 Control circuit with CK\_INT, TMRx\_DIV=0x0 and PR=0x16



### 15.4.3.2 Counting mode

The TMR10/11/13/14 supports multiple counting modes to meet various application scenarios. Each consists of a 16-bit upcounter.

The TMRx\_PR register is used to define counting period of counter. The value in the TMRx\_PR is immediately moved to the shadow register by default. When the periodic buffer is enabled (PRBEN=1), the value in the TMRx\_PR register is transferred to the shadow register only at an overflow event.

TMRx\_DIV register is used to define the counter frequency of the counter. The counter counts once every DIV[15:0]+1 clock cycle. The value of the TMRx\_DIV register are transferred into the shadow register at each overflow event.

Reading the TMRx\_CNT register returns the current counter value. Writing the TMRx\_CNT register will update the current counter value.

An overflow event is enabled by default. It can be disabled by setting OVFEN=1 in the TMRx\_CTRL1 register. The OVFS bit in the TMRx\_CTRL1 register is used to select the source of an overflow event, which is, by default, counter overflow or underflow, setting OVFSWTR, reset signal generated by slave mode timer controller in reset mode. Once the OVFS is set, an overflow event is generated only when overflow or underflow occurs.

Setting the TMREN bit (TMREN=1) enables the timer to start counting. Base on synchronization logic, however, the actual enable signal TMR\_EN is set 1 clock cycle after the TMREN is set.

Figure 15-69 Basic structure of a counter



#### Upcounting mode

This mode is enabled by setting TWCSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register. In upcounting mode, the counter counts from 0 to the value programmed in the TMRx\_PR register, restarts from 0, and generates a counter overflow event, with setting OVFIF bit to 1. If the overflow event is disabled, the counter is no longer reloaded with the prescaler and period value on counter overflow; otherwise, the prescaler and period value will be updated on an overflow event.

Figure 15-70 Overflow event when PRBEN=0



Figure 15-71 Overflow event when PRBEN=1



### Downcounting mode

This mode is enabled by setting TWCSEL[1:0]=2'b00 and OWCDIR=1'b1 in the TMRx\_CTRL1 register. In downcounting mode, the counter counts from the value programmed in the TMRx\_PR register down to 0, and restarts from the value programmed, and generates a counter underflow event.

Figure 15-72 Counter timing diagram with internal clock divided by 3



### Up/down counting mode (center-aligned mode)

This mode is selected by setting TWCSEL[1:0]≠2'b00 in the TMRx\_CTRL1 register.

In up/down counting mode, the counter counts up/down alternatively. When the counter counts from the value programmed in the TMRx\_PR register down to 1, an underflow event is generated, and then restarts counting from 0; When the counter counts from 0 to the value of the TMRx\_PR register -1, an overflow event is generated, and then restarts counting from the value of the TMRx\_PR register. The OWCDIR bit indicates the current counting direction.

The TWCSEL[1:0] bit in the TMRx\_CTRL1 register is used to select the condition under which the CxIF flag is set in two-way counting mode. In other words, when TWCSEL[1:0]=2'b01 (counting mode 1) is selected, the CxIF flag is set only when the counter counts down; when TWCSEL[1:0]=2'b10 (counting mode 2) is selected, the CxIF flag is set only when the counter counts up; when TWCSEL[1:0]=2'b11 (counting mode 3) is selected, the CxIF flag is set when the counter counts up and down.

*Note: The OWCDIR is read-only in up/down counting mode.*

Figure 15-73 Counter timing diagram with internal clock divided by 0 and TMRx\_PR=0x32

**Repetition counter mode:**

The TMRx\_RPR register is used to enable repetition counting mode. This mode is enabled when the repetition counter value is not equal to 0. In this mode, an overflow event is generated when a counter overflow occurs ( $RPR[7:0]+1$ ). The repetition counter is decremented at each counter overflow. An overflow event is generated when the repetition counter reaches 0. The frequency of the overflow event generation can be adjusted by setting the repetition counter value.

Figure 15-74 OVFIF in upcounting mode and central-aligned mode



### 15.4.3.3 TMR input function

Each of TMR10/11/13/14 has an independent channel that can be configured in input or output mode.

As input, the channel input signal is processed as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. The C1INSE bit is used to select TMRx\_CHx as the source of CxIRAW.
- CxIRAW goes through digital filter and generates the filtered CxIF signal. The digital filter uses the CxDF bit to program sampling frequency and sampling times.
- CxIF goes through edge detector and generates the CxIFPx signal after edge selection. The edge selection depends on both CxP and CxCp bits. It is possible to select input rising edge, falling edge or both edges.
- CxIFPx goes through capture signal selector and generates the CxIN signal after capture signal selection. The capture signal selection is defined by CxC bits. The CxIFPx can be used as a source of CxIN source.
- CxIN goes through input divider and generates the CxIPS signal. The divider factor can be defined as No division, /2, /4 or /8 by setting the CxIDIV bit.

Figure 15-75 Input/output channel 1 main circuit



Figure 15-76 Channel 1 input stage



#### Input mode

In input mode, the TMRx\_CxDT registers latches the current counter values after the selected trigger signal is detected, and the capture compare interrupt flag bit (CxIF) is set to 1. An interrupt/DMA request will be generated if the CxIEN bit and CxDEN bit are enabled. If the selected trigger signal is detected when the CxIF is set to 1, a capture overflow event is generated, the previous counter value will be overwritten with the current counter value, and the CxRF is set to 1.

To capture the rising edge of C1IN input, following the procedure below:

- Set C1C=01 in the TMRx\_CM1 register to select the C1IN as channel 1 input
- Set C1IN signal filter bandwidth (CxDF[3: 0])
- Set the active edge of C1IN channel by writing C1P=0 (rising edge) in the TMRx\_CCTRL register
- Program C1IN signal capture frequency divider (C1DIV[1: 0])
- Enable channel 1 input capture (C1EN=1)
- If needed, enable the relevant interrupt or DMA request by setting the C1IEN bit in the TMRx\_IDEN register or the C1DEN bit in the TMRx\_IDEN register

### 15.4.3.4 TMR output function

The TMR output consists of a comparator and an output controller. It is used to program the period, duty cycle and polarity of the output signal.

Figure 15-77 Channel 1 output stage



#### Output mode

Write  $CxC[1: 0] \neq 2'b00$  to configure the channel as output to implement multiple output modes. In this case, the counter value is compared with the value in the  $TMRx_{CxDT}$  register, and the intermediate signal  $CxORAW$  is generated according to the output mode selected by  $CxOCTRL[2: 0]$ , which is sent to IO after being processed by the output control circuit. The period of the output signal is configured by the  $TMR15_PR$  register, while the duty cycle by the  $TMRx_{CxDT}$  register.

#### PWM mode A:

Enable PWM mode A by setting  $CxOCTRL=3'b110$ . In upcounting mode,  $C1ORAW$  outputs high when  $TMRx_{C1DT} > TMRx_{CVAL}$ ; otherwise, it is low. In downcounting mode,  $C1ORAW$  outputs low when  $TMRx_{C1DT} < TMRx_{CVAL}$ ; otherwise, it is high. Figure 15-77 presents an example of PWM mode A in upcounting mode,  $PR=0x32$ , and  $CxDT$  with different values.

#### To use PWM mode A, the following procedures are recommended:

- Set PWM periods through  $TMRx_PR$  register
- Set PWM duty cycles through  $TMRx_{CxDT}$
- Select PWM mode A by setting  $CxOCTRL=3'b110$  in the  $TMRx_CM1/CM2$  register
- Set counting frequency through  $TMRx_DIV$  register
- Select counting mode by setting the  $TWCMSEL[1:0]$  bit in the  $TMRx_CTRL1$  register
- Select output polarity through the  $CxP$  and  $CxCP$  bits in the  $TMRx_CCTRL$  register
- Enable channel output through the  $CxEN$  and  $CxCEN$  bits in the  $TMRx_CCTRL$  register
- Enable TMRx output through the  $OEN$  bit in the  $TMRx_BRK$  register
- Configure GPIOs corresponding to TMR output channels as multiplexed mode
- Enable TMRx to start counting through the  $TMREN$  bit in the  $TMRx_CTRL1$  register.

Figure 15-78 PWM mode A in upcounting mode

**PWM mode B:**

Enable PWM mode B by setting CxOCTRL=3'b111. In upcounting mode, C1ORAW outputs low when TMRx\_C1DT>TMRx\_CVAL; otherwise, it is high. In downcounting mode, C1ORAW outputs high when TMRx\_C1DT<TMRx\_CVAL; otherwise, it is low.

**Forced output mode:**

Enable forced output mode by setting CxOCTRL=3'b100/101. In this case, the CxORAW is forced to be the programmed level, regardless of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.

**Output compare mode:**

Enable output compare mode by setting CxOCTRL=3'b001/010/011. In this case, when the counter value matches the value of the CxDT register, the CxORAW is forced high (CxOCTRL=3'b001), low (CxOCTRL=3'b010) or toggling (CxOCTRL=3'b011). Figure 15-78 presents an example of output compare mode, C1DT=0x3. When the counter value is 0x3, C1OUT toggles.

Figure 15-79 C1ORAW toggles when counter value matches C1DT value

**One-pulse mode:**

This is a particular case of PWM mode. Enable one-pulse by setting OCMEN=1. In this mode, the comparison match is performed in the current counting period. The TMREN bit is cleared as soon as the current counting is completed. Therefore, only one pulse is output. When in upcounting mode, the configuration must follow the rule: CVAL<CxDT≤PR; in downcounting mode, CVAL>CxDT is required. Figure 15-79 presents an example of PWM B in upcounting mode & one-pulse mode. The counter counts a single cycle, and only a single pulse is output during this cycle.

Figure 15-80 One-pulse mode

**Fast output mode:**

Enable this mode by setting  $CxOEN=1$ . If enabled, the  $CxORAW$  signal will not change when the counter value matches the  $CxDT$ , but change at the beginning of the current counting period. In other words, the comparison result is advanced, so the comparison result between the counter value and the  $TMRx_CxDT$  register will determine the level of  $CxORAW$  in advance.

**Dead-time insertion**

The  $TMRx$  contains a set of reverse channel output. This function is enabled by the  $CxCEN$  bit and its polarity is selected by  $CxCP$ . Refer to Table 15-15 for more information about the output state of  $CxOUT$  and  $CxCOUT$ .

The dead-time is activated when switching to IDLEF state ( $OEN$  falling down to 0).

Setting both  $CxEN$  and  $CxCEN$  bits, and using  $DTC[7:0]$  bit to insert dead-time of different durations. After the dead-time insertion, the rising edge of the  $CxOUT$  is delayed compared to the rising edge of the reference signal; the rising edge of the  $CxCOUT$  is delayed compared to the falling edge of the reference signal.

If the delay is greater than the width of the active output,  $C1OUT$  and  $C1COUT$  will not generate corresponding pulses. Therefore, the dead-time should be less than the width of the active output.

[Figure 15-81](#) gives an example of dead-time insertion when  $CxP=0$ ,  $CxCP=0$ ,  $OEN=1$ ,  $CxEN=1$  and  $CxCEN=1$ .

Figure 15-81 Complementary output with dead-time insertion



### 15.4.3.5 TMR brake function

When the break function is enabled (BRKEN=1), the CxOUT and CxCOUT are jointly controlled by OEN, FCSODIS, FCSOEN, CxIOS and CxCIOS. But, CxOUT and CxCOUT cannot be set both to active level at the same time. Please refer to Table 15-15 for more details.

The brake source can be a brake input pin or a clock failure event. The polarity is controlled by BRKV bit.

When a brake event occurs, there are the following actions:

- The OEN bit is cleared asynchronously, and the channel output state is selected by setting the FCSODIS bit. This function works even if the MCU oscillator is off.
- Once OEN=0, the channel output level is defined by the CxIOS bit. If FCSODIS=0, the timer output is disabled; otherwise, the output enable remains high.
- When complementary outputs are used:
  - The outputs are first put in reset state, that is, inactive state (depending on the polarity). This is done asynchronously so that it works even if no clock is provided to the timer.
  - If the timer clock is still active, then the dead-time generator is activated. The CxIOS and CxCIOS bits are used to program the level after dead-time. Even in this case, the CxIOS and CxCIOS cannot be driven to their active level at the same time.

*Note: Because of synchronization logic on OEN bit, the dead-time duration is usually longer than usual (around 2 clk\_tmr clock cycles)*

- If FCSODIS=0, the timer releases the enable output; otherwise, it keeps the enable output; the enable output becomes high as soon as one of the CxEN and CxCEN bits becomes high.
- If the brake interrupt or DMA request is enabled, the brake status flag is set, and a brake interrupt or DMA request can be generated.
- If AOEN=1, the OEN bit is automatically set again at the next overflow event.

*Note: When the brake input is active, the OEN cannot be set, nor the status flag, BRKIF can be cleared.*

Figure 15-82 TMR output control



Figure 15-83 Example of TMR brake function



### 15.4.3.6 TMR DMA

TMR has the following events for DMA transfer request: overflow event DMA request, trigger event DMA request, Hall sensor DMA request and channel event DMA request. It is possible to enable DMA request by setting the TMRx\_IDEN register. Once enabled, upon an event generated, a DMA request is triggered and output to the DMA peripheral.

#### TMR DMA Burst feature

TMR also supports TMR DMA Burst feature. Thanks to this feature, DMA can be triggered to rewrite multiple TMR consecutive registers by enabling a certain DMA request through the TMRx\_IDEN register.

As an overflow event to trigger TMR DMA Burst as an example:

- Enable overflow event to trigger DMA request using the OVFDEN bit in the TMRx\_IDEN register
- Configure Burst transfer times using the DTB bit in the TMRx\_DMACTRL register
- Configure the start address of Burst transfer using the ADDR bit in the TMRx\_DMACTRL register
- Enable counter

After the above-mentioned configurations, here is the whole process of TMR DMA Burst transfer:

Upon an overflow event, the TMR will send a DMA request to the DMA peripheral. Then the DMA writes the data into the TMRx\_DMADT register as requested. Inside TMR, the DMADT bit data is written into the start address register of Burst transfer and an ACK single is sent to TMR. After receiving this ACK, the TMR clears the current DMA request; when the Burst transfer is detected by the TMR not to complete fully, a new overflow event for DMA request is released to the DMA so that the DMA writes the requested data into the TMRx\_DMADT again. In this case, inside tmr, the DMADT register data is written into the Burst transfer start address + 0x4 address register, and a new ACK is sent to TMR, and so on, and so on, until the last operation of Burst transfer. When a full Burst transfer is complete, the REQ for overflow event DMA request would not be set any more until the next overflow event.

*Note: when using TMR DMA Burst feature, an empty register is prohibited and the TMRx\_DMACTRL as well as TMRx\_DMADT registers should not be available during the period from the start address to the end address.*

### 15.4.3.7 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the TMRx counter stops counting by setting the TMRx\_PAUSE in the DEBUG module.

## 15.4.4 TMRx registers

Table 15-10 TMR10/11/13/14 register map and reset value

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| TMRx_CTRL1   | 0x00   | 0x0000 0000 |
| TMRx_CTRL2   | 0x04   | 0x0000 0000 |
| TMRx_IDEN    | 0x0C   | 0x0000 0000 |
| TMRxISTS     | 0x10   | 0x0000 0000 |
| TMRx_SWEVT   | 0x14   | 0x0000 0000 |
| TMRx_CM1     | 0x18   | 0x0000 0000 |
| TMRx_CCTRL   | 0x20   | 0x0000 0000 |
| TMRx_CVAL    | 0x24   | 0x0000 0000 |
| TMRx_DIV     | 0x28   | 0x0000 0000 |
| TMRx_PR      | 0x2C   | 0x0000 FFFF |
| TMRx_RPR     | 0x30   | 0x0000 0000 |
| TMRx_C1DT    | 0x34   | 0x0000 0000 |
| TMRx_BRK     | 0x44   | 0x0000 0000 |
| TMRx_DMACTRL | 0x48   | 0x0000 0000 |
| TMRx_DMADT   | 0x4C   | 0x0000 0000 |
| TMR14_RMP    | 0x50   | 0x0000 0000 |

### 15.4.4.1 TMRx control register 1 (TMRx\_CTRL1) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x00 0000   | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | Clock divider<br>This field is used to define the division ratio between digital filter sampling frequency ( $f_{DTS}$ ) and timer clock frequency ( $f_{CK\_INT}$ ). it is also used to set the division ratio between dead time base ( $T_{DTS}$ ) and timer clock period ( $T_{CK\_INT}$ )<br>00: No division, $f_{DTS}=f_{CK\_INT}$<br>01: Divided by 2, $f_{DTS}=f_{CK\_INT}/2$<br>10: Divided by 4, $f_{DTS}=f_{CK\_INT}/4$<br>11: Reserved                                                             |
| Bit 7      | PRBEN    | 0x0         | rw   | Period buffer enable<br>0: Period buffer is disabled<br>1: Period buffer is enabled                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 6: 5   | TWCMSEL  | 0x0         | rw   | Two-way counting mode selection<br>00: One-way counting mode, depending on the OWCDIR bit<br>01: Two-way counting mode 1, The counter counts up and down alternately, the CxIF bit is set only when the counter is counting down<br>10: Two-way counting mode 2, The counter counts up and down alternately, the CxIF bit is set only when the counter is counting up<br>11: Two-way counting mode 3, The counter counts up and down alternately, the CxIF bit is set when the counter is counting up or down |
| Bit 4      | OWCDIR   | 0x0         | rw   | One-way count direction<br>0: Up<br>1: Down                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 3      | OCMEN    | 0x0         | rw   | One cycle mode enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|       |       |     |    |                                                                                                                                                                                                                                                          |
|-------|-------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | This bit is used to select whether to stop counting at an update event<br>0: The counter does not stop at an update event<br>1: The counter stops at an update event                                                                                     |
| Bit 2 | OVFS  | 0x0 | rw | Overflow event source<br>This bit is used to select overflow event or DMA request sources.<br>0: Counter overflow, setting the OVFSWTR bit or overflow event generated by slave timer controller<br>1: Only counter overflow generates an overflow event |
| Bit 1 | OVFEN | 0x0 | rw | Overflow event enable<br>0: Enabled<br>1: Disabled                                                                                                                                                                                                       |
| Bit 0 | TMREN | 0x0 | rw | TMR enable<br>0: Enabled<br>1: Disabled                                                                                                                                                                                                                  |

#### 15.4.4.2 TMRx control register 2 (TMRx\_CTRL2) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                      |
| Bit 9      | C1CIOS   | 0x0         | rw   | Channel 1 complementary idle output state<br>Output disabled (OEN = 0), after dead-time:<br>0: C1OUTL=0<br>1: C1OUTL=1                                                                                                                                                                      |
| Bit 8      | C1IOS    | 0x0         | rw   | Channel 1 idle output state<br>Output disabled (OEN = 0), after dead-time:<br>0: C1OUT=0<br>1: C1OUT=1                                                                                                                                                                                      |
| Bit 7:4    | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                      |
| Bit 3      | DRS      | 0x0         | rw   | DMA request source<br>0: Capture/compare event<br>1: Overflow event                                                                                                                                                                                                                         |
| Bit 2      | CCFS     | 0x0         | rw   | Channel control bit flash selection<br>This bit only acts on channels with complementary output. If the channel control bits are buffered:<br>0: Control bits are updated by setting the HALLSWTR bit<br>1: Control bits are updated by setting the HALLSWTR bit or a rising edge on TRGIN. |
| Bit 1      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                      |
| Bit 0      | CBCTRL   | 0x0         | rw   | Channel buffer control<br>This bit acts on channels that have complementary output.<br>0: CxEN, CxCEN and CxOCTRL bits are not buffered.<br>1: CxEN, CxCEN and CxOCTRL bits are buffered.<br>Note: when CBCTRL="1", CxEN, CxCEN and CxOCTRL bits can be updated only upon a HALL event.     |

#### 15.4.4.3 TMRx DMA/interrupt enable register (TMRx\_IDEN) (x=10/11/13/14)

| Bit       | Name     | Reset value | Type | Description                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------|
| Bit 31:10 | Reserved | 0x00 0000   | resd | Kept at default value.                                         |
| Bit 9     | C1DEN    | 0x0         | rw   | Channel 1 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 8     | OVFDEN   | 0x0         | rw   | Overflow event DMA request enable<br>0: Disabled<br>1: Enabled |
| Bit 7     | BRKIE    | 0x0         | rw   | Brake interrupt enable<br>0: Disabled<br>1: Enabled            |

|          |          |     |      |                                                         |
|----------|----------|-----|------|---------------------------------------------------------|
| Bit 6    | Reserved | 0x0 | resd | Kept at default value.                                  |
| Bit 5    | HALLIEN  | 0x0 | rw   | HALL interrupt enable<br>0: Disabled<br>1: Enabled      |
| Bit 4: 2 | Reserved | 0x0 | resd | Kept at default value.                                  |
| Bit 1    | C1IEN    | 0x0 | rw   | Channel 1 interrupt enable<br>0: Disabled<br>1: Enabled |
| Bit 0    | OVFIEN   | 0x0 | rw   | Overflow interrupt enable<br>0: Disabled<br>1: Enabled  |

#### 15.4.4.4 TMRx interrupt status register (TMRxISTS) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 9      | C1RF     | 0x0         | rw0c | Channel 1 recapture flag<br>This bit indicates whether a recapture is detected when C1IF=1. This bit is set by hardware, and cleared by writing "0".<br>0: No capture is detected<br>1: Capture is detected.                                                                                                                                                                                                                                             |
| Bit 8      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 7      | BRKIF    | 0x0         | rw0c | Brake interrupt flag<br>This bit indicates whether the brake input is active or not.<br>It is set by hardware and cleared by writing "0"<br>0: Inactive level<br>1: Active level                                                                                                                                                                                                                                                                         |
| Bit 6      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 5      | HALLIF   | 0x0         | rw0c | HALL interrupt flag<br>This bit is set by hardware on HALL event. It is cleared by writing "0".<br>0: No Hall event occurred.<br>1: Hall event is detected.<br>HALL even: CxEN, CxCEN and CxOCTRL are updated.                                                                                                                                                                                                                                           |
| Bit 4: 2   | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 1      | C1IF     | 0x0         | rw0c | Channel 1 interrupt flag<br>If the channel 1 is configured as input mode:<br>This bit is set by hardware on a capture event. It is cleared by software or read access to the TMRx_C1DT<br>0: No capture event occurred<br>1: Capture event is generated<br>If the channel 1 is configured as output mode:<br>This bit is set by hardware on a compare event. It is cleared by software.<br>0: No compare event occurred<br>1: Compare event is generated |
| Bit 0      | OVFIF    | 0x0         | rw0c | Overflow interrupt flag<br>This bit is set by hardware on an overflow event. It is cleared by software.<br>0: No overflow event occurred<br>1: Overflow event is generated. If OVFEN=0 and OVFS=0 in the TMRx_CTRL1 register:<br>- An overflow event is generated when OVFSWTR= 1 in the TMRx_SWEVT register;<br>- An overflow event is generated when the counter CVAL is reinitialized by a trigger event.                                             |

#### 15.4.4.5 TMRx software event register (TMRx\_SWEVT) (x=10/11/13/14)

| Bit       | Name     | Reset value | Type | Description                                                                                                 |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                      |
| Bit 7     | BRKSWTR  | 0x0         | wo   | Brake event triggered by software<br>This bit is set by software to generate a brake event.<br>0: No effect |

|          |          |     |      |                                                                                                              |
|----------|----------|-----|------|--------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 1: Generate a brake event.                                                                                   |
| Bit 6    | Reserved | 0x0 | resd | Kept at default value.                                                                                       |
|          |          |     |      | HALL event triggered by software<br>This bit is set by software to generate a HALL event.                    |
| Bit 5    | HALLSWTR | 0x0 | wo   | 0: No effect<br>1: Generate a HALL event.<br>Note: This bit acts only on channels with complementary output. |
| Bit 4: 2 | Reserved | 0x0 | resd | Kept at default value.                                                                                       |
|          |          |     |      | Channel 1 event triggered by software                                                                        |
| Bit 1    | C1SWTR   | 0x0 | wo   | This bit is set by software to generate a channel 1 event.<br>0: No effect<br>1: Generate a channel 1 event. |
|          |          |     |      | Overflow event triggered by software                                                                         |
| Bit 0    | OVFSWTR  | 0x0 | wo   | This bit is set by software to generate an overflow event.<br>0: No effect<br>1: Generate an overflow event. |

#### 15.4.4.6 TMRx channel mode register 1 (TMRx\_CM1) (x=10/11/13/14)

The channel can be used in input (capture mode) or output (compare mode). The direction of a channel is defined by the corresponding CxC bits. All the other bits of this register have different functions in input and output modes. The CxOx describes its function in output mode when the channel is in output mode, while the Cxlx describes its function in output mode when the channel is in input mode. Attention must be given to the fact that the same bit can have different functions in input mode and output mode.

##### Output compare mode:

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x000 0000  | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 31: 7 |          |             |      | Channel 1 output control<br>This field defines the behavior of the original signal C1ORAW.<br>000: Disconnected. C1ORAW is disconnected from C1OUT;<br>001: C1ORAW is high when TMRx_CVAL=TMRx_C1DT<br>010: C1ORAW is low when TMRx_CVAL=TMRx_C1DT<br>011: Switch C1ORAW level when TMRx_CVAL=TMRx_C1DT<br>100: C1ORAW is forced low<br>101: C1ORAW is forced high.<br>110: PWM mode A<br>— OWCDIR=0, C1ORAW is high once TMRx_C1DT>TMRx_CVA, else low;<br>— OWCDIR=1, C1ORAW is low once TMRx_C1DT<TMRx_CVA, else high;<br>111: PWM mode B<br>— OWCDIR=0, C1ORAW is low once TMRx_C1DT>TMRx_CVAL, else high;<br>— OWCDIR=1, C1ORAW is high once TMRx_C1DT<TMRx_CVAL, else low.<br><i>Note: In the configurations other than 000', the C1OUT is connected to C1ORAW. The C1OUT output level is not only subject to the changes of C1ORAW, but also the output polarity set by CCTRL.</i> |
| Bit 6: 4  | C1OCTRL  | 0x0         | rw   | Channel 1 output buffer enable<br>0: Buffer function of TMRx_C1DT is disabled. The new value written to the TMRx_C1DT takes effect immediately.<br>1: Buffer function of TMRx_C1DT is enabled. The value to be written to the TMRx_C1DT is stored in the buffer register, and can be sent to the TMRx_C1DT register only on an overflow event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 3     | C1OBEN   | 0x0         | rw   | Channel 1 output enable immediately                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 2     | C1OIEN   | 0x0         | rw   | Channel 1 output enable immediately                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|                            |          |           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------|----------|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |          |           |      | In PWM mode A or B, this bit is used to accelerate the channel 1 output's response to the trigger event.<br>0: Need to compare the CVAL with C1DT before generating an output<br>1: No need to compare the CVAL and C1DT. An output is generated immediately when a trigger event occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 1: 0                   | C1C      | 0x0       | rw   | Channel 1 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':<br>00: Output<br>01: Input, C1IN is mapped on C1IFP1<br>10: Reserved<br>11: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Input capture mode:</b> |          |           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 31: 8                  | Reserved | 0x00 0000 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 7: 4                   | C1DF     | 0x0       | rw   | Channel 1 digital filter<br>This field is used to set the filter for channel 1. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output.<br>0000: No filter, sampling is done at $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
| Bit 3: 2                   | C1IDIV   | 0x0       | rw   | Channel 1 input divider<br>This field defines Channel 1 input divider.<br>00: No divider. An input capture is generated at each active edge.<br>01: An input compare is generated every 2 active edges<br>10: An input compare is generated every 4 active edges<br>11: An input compare is generated every 8 active edges<br>Note: the divider is reset once C1EN='0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 1: 0                   | C1C      | 0x0       | rw   | Channel 1 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':<br>00: Output<br>01: Input, C1IN is mapped on C1IFP1<br>10: Reserved<br>11: Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 15.4.4.7 TMRx Channel control register (TMRx\_CCTRL) (x=10/11/13/14)

| Bit       | Name     | Reset value | Type | Description                                                                               |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------|
| Bit 31: 4 | Reserved | 0x000 0000  | resd | Kept at default value.                                                                    |
| Bit 3     | C1CP     | 0x0         | rw   | Channel 1 complementary polarity<br>0: C1COUT is active high.<br>1: C1COUT is active low. |

|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 2 | C1CEN | 0x0 | rw | Channel 1 complementary enable<br>0: Output is disabled.<br>1: Output is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 1 | C1P   | 0x0 | rw | Channel 1 polarity<br>When the channel 1 is configured in output mode:<br>0: C1OUT is active high<br>1: C1OUT is active low<br>When the channel 1 is configured in input mode:<br>The active edge of the input signal is defined by C1CP/C1P.<br>00: C1IN active edge is on its rising edge. When used as external trigger, C1IN is not inverted.<br>01: C1IN active edge is on its falling edge. When used as external trigger, C1IN is inverted.<br>10: Reserved<br>11: C1IN active edge is on its falling edge and rising edge. When used as external trigger, C1IN is not inverted. |
| Bit 0 | C1EN  | 0x0 | rw | Channel 1 enable<br>0: Input or output is disabled<br>1: Input or output is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Table 15-11 Complementary output channel CxOUT and CxCOUT control bits with brake function

| Control bit |             |            | Output state <sup>(1)</sup> |           |                                                                                                                                                                    |                                                                              |
|-------------|-------------|------------|-----------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| OEN bit     | FCSODIS bit | FCSOEN bit | CxEN bit                    | CxCEN bit | CxOUT output state                                                                                                                                                 | CxCOUT output state                                                          |
| 1           | X           | 0          | 0                           | 0         | Output disabled<br>(no driven by the timer)<br>CxOUT=0, Cx_EN=0                                                                                                    | Output disabled<br>(no driven by the timer)<br>CxOUT=0, CxCEN=0              |
|             |             | 0          | 0                           | 1         | Output disabled<br>(no driven by the timer)<br>CxOUT=0, Cx_EN=0                                                                                                    | CxORAW + polarity,<br>CxOUT= CxORAW xor<br>CxCP, CxCEN=1                     |
|             |             | 0          | 1                           | 0         | CxORAW+ polarity<br>CxOUT= CxORAW xor CxP,<br>Cx_EN=1                                                                                                              | Output disabled<br>(no driven by the timer)<br>CxOUT=0, CxCEN=0              |
|             |             | 0          | 1                           | 1         | CxORAW+polarity+<br>dead-time,<br>Cx_EN=1                                                                                                                          | CxORAW<br>inverted+polarity+dead-<br>time,<br>CxCEN=1                        |
|             |             | 1          | 0                           | 0         | Output disabled<br>(no driven by the timer)<br>CxOUT=CxP, Cx_EN=0                                                                                                  | Output disabled<br>(no driven by the timer)<br>CxOUT=CxP,<br>CxEN=0          |
|             |             | 1          | 0                           | 1         | Off-state<br>(Output enabled with<br>inactive level)<br>CxOUT=CxP, Cx_EN=1                                                                                         | CxORAW + polarity,<br>CxOUT= CxORAW xor<br>CxCP, CxCEN=1                     |
|             |             | 1          | 1                           | 0         | CxORAW + polarity,<br>CxOUT= CxORAW xor CxP,<br>Cx_EN=1                                                                                                            | Off-state<br>(Output enabled with<br>inactive level)<br>CxOUT=CxP,<br>CxEN=1 |
|             |             | 1          | 1                           | 1         | CxORAW+ polarity+dead-<br>time, Cx_EN=1                                                                                                                            | CxORAW<br>inverted+polarity+dead-<br>time,<br>CxCEN=1                        |
| 0           | X           | 0          | 0                           | 0         | Output disabled (corresponding IO is not driven by the timer, IO floating)                                                                                         |                                                                              |
|             |             | 0          | 0                           | 1         | Asynchronously: CxOUT=CxP, Cx_EN=0,<br>CxOUT=CxP, CxCEN=0;                                                                                                         |                                                                              |
|             |             | 0          | 1                           | 0         | If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level. |                                                                              |
|             |             | 0          | 1                           | 1         | CxEN=CxCEN=0: output disabled (corresponding IO is<br>not driven by the timer, IO floating)                                                                        |                                                                              |
|             |             | 1          | 0                           | 0         | In other cases: off-state (corresponding channel output<br>invalid level)                                                                                          |                                                                              |
|             |             | 1          | 0                           | 1         | Asynchronously: CxOUT =CxP, Cx_EN=1,<br>CxOUT=CxP, CxCEN=1;                                                                                                        |                                                                              |
|             |             | 1          | 1                           | 0         | If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level. |                                                                              |
|             |             | 1          | 1                           | 1         |                                                                                                                                                                    |                                                                              |

Note: If the two outputs of a channel are not used (CxEN = CxCEN = 0), CxIOS, CxCIOS, CxP and CxCP must be cleared.

Note: The state of the external I/O pins connected to the complementary CxOUT and CxCOUT channels depends on the CxOUT and CxCOUT channel state and the GPIO and the IOMUX registers.

#### 15.4.4.8 TMRx counter value register (TMRx\_CVAL) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description            |
|------------|----------|-------------|------|------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value. |
| Bit 15: 0  | CVAL     | 0x0000      | rw   | Counter value          |

#### 15.4.4.9 TMRx division value register (TMRx\_DIV) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                     |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                          |
| Bit 15: 0  | DIV      | 0x0000      | rw   | Divider value<br>The counter clock frequency $f_{CK\_CNT} = f_{TMR\_CLK} / (\text{DIV}[15:0]+1)$ .<br>The value of this register is transferred to the actual prescaler register when an overflow event occurs. |

#### 15.4.4.10 TMRx period register (TMRx\_PR) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                            |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                 |
| Bit 15: 0  | PR       | 0xFFFF      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

#### 15.4.4.11 TMRx repetition period register (TMRx\_RPR) (x=10/11/13/14)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                              |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | rw   | Kept at default value                                                                                                                                                    |
| Bit 7: 0  | RPR      | 0x00        | rw   | Repetition of period value<br>This field is used to reduce the generation rate of overflow events. An overflow event is generated when the repetition counter reaches 0. |

#### 15.4.4.12 TMRx channel 1 data register (TMRx\_C1DT) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | rw   | Kept at default value                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 15: 0  | C1DT     | 0x0000      | rw   | Channel 1 data register<br>When the channel 1 is configured as input mode:<br>The C1DT is the CVAL value stored by the last channel 1 input event (C1IN).<br>When the channel 1 is configured as output mode:<br>C1DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C1OBEN bit, and the corresponding output is generated on C1OUT as configured. |

#### 15.4.4.13 TMRx brake register (TMRx\_BRK) (x=10/11/13/14)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved | 0x000       | rw   | Kept at default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 19: 16 | BKF      | 0x0         | rw   | Brake input filter<br>This field is used to set the filter for brake input. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output.<br>0000: No filter, sampling is done at $f_{DTS}$<br>0001: $f_{SAMPLING}=f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING}=f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING}=f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING}=f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING}=f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING}=f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING}=f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING}=f_{DTS}/8$ , N=6 |

|          |         |      |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|---------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |         |      |    | 1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8                                                                                                                                                                                                                                                                                                                                                 |
|          |         |      |    | Output enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 15   | OEN     | 0x0  | rw | This bit acts on the channels as output. It is used to enable CxOUT and CxCOUT outputs.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 14   | AOEN    | 0x0  | rw | Automatic output enable<br>OEN is set automatically at an overflow event.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 13   | BRKV    | 0x0  | rw | Brake input validity<br>This bit is used to select the active level of a brake input.<br>0: Brake input is active low.<br>1: Brake input is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 12   | BRKEN   | 0x0  | rw | Brake enable<br>This bit is used to enable brake input.<br>0: Brake input is disabled.<br>1: Brake input is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 11   | FCSOEN  | 0x0  | rw | Frozen channel status when holistic output enable<br>This bit acts on the channels that have complementary output. It is used to set the channel state when the timer is inactive and OEN=1.<br>0: CxOUT/CxCOUT outputs are disabled.<br>1: CxOUT/CxCOUT outputs are enabled. Output inactive level.                                                                                                                                                                                                                                                                                                                                                     |
| Bit 10   | FCSODIS | 0x0  | rw | Frozen channel status when holistic output disable<br>This bit acts on the channels that have complementary output. It is used to set the channel state when the timer is inactive and OEN=0.<br>0: CxOUT/CxCOUT outputs are disabled.<br>1: CxOUT/CxCOUT outputs are enabled. Output idle level.                                                                                                                                                                                                                                                                                                                                                        |
| Bit 9: 8 | WPC     | 0x0  | rw | Write protection configuration<br>This field is used to enable write protection.<br>00: Write protection is OFF.<br>01: Write protection level 3, and the following bits are write protected:<br>TMRx_STOP: BRKF, DTC, STPEN, STPV and HOAEN<br>TMRx_CTRL2: C1IOS and C1C1OS<br>10: Write protection level 2. The following bits and all bits in level 3 are write protected:<br>TMRx_CCTRL: C1P and C1CP<br>TMRx_STOP: FCSODIS and FCSOEN<br>11: Write protection level 1. The following bits and all bits in level 2 are write protected:<br>TMRx_CM1: C1OCTRL and C1OBEN<br>Note: Once WPC>0, its content remains frozen until the next system reset. |
| Bit 7: 0 | DTC     | 0x00 | rw | Dead-time configuration<br>This field defines the duration of the dead-time insertion. The 3-bit MSB of DTC[7: 0] is used for function selection:<br>0xx: DT = DTC [7: 0] * TDTS<br>10x: DT = (64+ DTC [5: 0]) * TDTS * 2<br>110: DT = (32+ DTC [4: 0]) * TDTS * 8<br>111: DT = (32+ DTC [4: 0]) * TDTS * 16                                                                                                                                                                                                                                                                                                                                             |

Note: Based on lock configuration, BRKF, AOEN, BRKV, BRKEN, FCSODIS, FCSOEN and DTC[7:0] can all be write protected. But they must be configured when the first write access to the TMRx\_BRK register for the first time.

#### 15.4.4.14 TMRX DMA control register (TMRX\_DMACTRL) (X=10/11/13/14)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                        |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:13 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                                             |
|           |          |             |      | DMA transfer bytes<br>This field defines the number of DMA transfers:<br>00000: 1 byte      00001: 2 bytes<br>00010: 3 bytes      00011: 4 bytes<br>.....                .....10000: 17 bytes      10001: 18 bytes |
| Bit 12:8  | DTB      | 0x00        | rw   |                                                                                                                                                                                                                    |
| Bit 7:5   | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                             |
|           |          |             |      | DMA transfer address offset<br>ADDR is defined as an offset starting from the address<br>of the TMRx_CTRL1 register:<br>00000: TMRx_CTRL1<br>00001: TMRx_CTRL2<br>00010: TMRx_STCTRL<br>.....                      |
| Bit 4: 0  | ADDR     | 0x00        | rw   |                                                                                                                                                                                                                    |

#### 15.4.4.15 TMRx DMA data register (TMRx\_DMADT) (X=10/11/13/14)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                         |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                              |
|           |          |             |      | DMA data register<br>A write/read operation to the DMADT register accesses<br>any TMR register located at the following address:<br>TMRx peripheral address + ADDR*4 to TMRx peripheral<br>address + ADDR*4 + DTB*4 |
| Bit 15: 0 | DMADT    | 0x0000      | rw   |                                                                                                                                                                                                                     |

#### 15.4.4.16 TMR14 channel input remap register (TMRx\_RMP)

| Bit       | Name           | Reset value | Type | Description                                                                                                                                         |
|-----------|----------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved       | 0x00 0000   | resd | Kept at default value.                                                                                                                              |
|           |                |             |      | TMR14 channel 1 input remap<br>00: TMR14 channel 1 input is connected to GPIO<br>01: ERTC_CLK<br>10: Divided ERTC 32 is used as HEXT<br>11: CLK_OUT |
| Bit 7: 6  | TMR14_CH1_IRMP | 0x0         | rw   |                                                                                                                                                     |
| Bit 5: 0  | Reserved       | 0x00        | resd | Kept at default value.                                                                                                                              |

## 15.5 Advanced-control timer (TMR1)

### 15.5.1 TMR1 introduction

The advanced-control timer TMR1 consists of a 16-bit counter supporting up and down counting modes. It has four channel registers, and four independent channels for dead-time insertion, input capture and programmable PWM output.

### 15.5.2 TMR1 main features

- Counter clock sources: internal clock, external clock an internal trigger input
- 16-bit up, down, up/down, repetition and encoder mode counter
- Four independent channels for input capture, output compare, PWM generation, one-pulse mode output and dead-time insertion
- Three independent channels with complementary output
- TMR brake function
- Synchronization control between master and slave timers
- Interrupt/DMA generation at overflow event, trigger event, and channel events
- Support TMR burst DMA transfer

Figure 15-84 Block diagram of advanced-control timer



### 15.5.3 TMR1 functional overview

#### 15.5.3.1 Counting clock

The count clock of TMR1 can be provided by the internal clock (CK\_INT), external clock (external clock mode A and B) and internal trigger input (ISx).

Figure 15-85 Counting clock



### Internal clock (CK\_INT)

By default, the CK\_INT which is divided by the prescaler, is used to drive the counter to start counting. When TMR's APB clock prescaler factor is 1, the CK\_INT frequency is equal to that of the APB; otherwise, it doubles the APB clock frequency.

- Set CK\_INT frequency through the CLKDIV[1:0] bit in the TMRx\_CTRL1 register
- Select a counting mode by setting the TWCMSEL[1:0] in TMRx\_CTRL1 register. If a unidirectional aligned counting mode is selected, it is necessary to select a counting direction through the OWCDIR in TMRx\_CTRL1 register.
- Set counting frequency through TMRx\_DIV register
- Set counting cycles through TMRx\_PR register
- Enable a counter by setting the TMREN bit in the TMRx\_CTRL1 register

Figure 15-86 Control circuit with CK\_INT, TMRx\_DIV=0x0 and TMRx\_PR=0x16



### External clock (TRGIN/EXT)

The counter clock can be provided by two external clock sources, namely, TRGIN and EXT signals.

**SMSEL=3'b111:** External clock mode A is selected. By setting the STIS[2:0] bit, select an external clock source TRGIN signal to drive the counter to start counting.

The external clock sources include:

C1INC (STIS=3'b100, channel 1 rising edge and falling edge)

C1IFP1 (STIS=3'b101, a signal after channel 1 filter and polarity selection)

C2IFP2 (STIS=3'b110, a signal after channel 2 filter and polarity selection)

EXT (STIS=3'b111, external input signal after polarity selection, frequency division and filter).

**ECMBEN=1:** External clock mode B is selected. The counter is driven by external input that has gone through polarity selection, frequency division and filtering. The external clock mode B is equivalent to the external clock mode A, and the EXT signal is used as an external force TRGIN,

#### To use external clock mode A, follow the steps below:

- Set external source TRGIN parameters

If the TMRx\_CH1 is used as a source of TRGIN, it is necessary to configure channel 1 input filter (C1DF[3:0] in TMRx\_CM1 register) and channel 1 input polarity (C1P/C1CP in TMRx\_CCTRL register);

If the TMRx\_CH2 is used as source of TRGIN, it is necessary to configure channel 1 input filter (C2DF[3:0] in TMRx\_CM1 register) and channel 2 input polarity (C2P/C2CP in TMRx\_CCTR register);

If the TMRx\_EXT is used as a source of TRGIN, it is necessary to configure the external signal polarity (ESP in TMRx\_STCTRL register), external signal frequency division (ESDIV[1:0] in TMRx\_STCTRL) and external signal filter (ESF[3:0] in TMRx\_STCTRL register).

- Set TRGIN signal source through the STIS[1:0] bit in TMRx\_STCTRL register
- Enable external clock mode A by setting SMSEL=3'b111 in TMRx\_STCTR register
- Set counting frequency through the DIV[15:0] in TMRx\_DIV register
- Set counting period through the PR[15:0] in TMRx\_PR register
- Enable counter through the TMREN bit in TMRx\_CTRL1 register

**To use external clock mode B, follow the steps below:**

- Set external signal polarity through the ESP bit in TMRx\_STCTRL register
- Set external signal frequency division through the ESDIV[1:0] bit in TMRx\_STCTRL register
- Set external signal filter through the ESF[3:0] bit in TMRx\_STCTRL register
- Enable external clock mode B through the ECMBEN bit in TMRx\_STCTR register
- Set counting frequency through the DIV[15:0] bit in TMRx\_DIV register
- Set counting period through the PR[15:0] bit in TMRx\_PR register
- Enable counter through the TMREN in TMRx\_CTRL1 register

Figure 15-87 Block diagram of external clock mode A



*Note: The delay between the signal on the input side and the actual clock of the counter is due to the synchronization circuit.*

Figure 15-88 Counting in external clock mode A, PR=0x32 and DIV=0x0



Figure 15-89 Block diagram of external clock mode B



*Note: The delay between the EXT signal on the input side and the actual clock of the counter is due to the synchronization circuit.*

Figure 15-90 Counting in external clock mode B, PR=0x32 and DIV=0x0

**Internal trigger input (ISx)**

Timer synchronization allows interconnection between several timers. The TMR\_CLK of one timer can be provided by the TRGOOUT signal output by another timer. Set the STIS[2:0] bit to select internal trigger signal to enable counting.

The advanced-control timer consists of a 16-bit prescaler, which is used to generate the CK\_CNT that enables the counter to count. The frequency division relationship between the CK\_CNT and TMR\_CLK can be adjusted by setting the value of the TMR1\_DIV register. The prescaler value can be modified at any time, but it takes effect only when the next overflow event occurs.

Below is the configuration procedure for internal trigger input:

- Set counting cycles through TMRx\_PR register
- Set counting frequency through TMRx\_DIV register
- Set counting modes through the TWCMSEL[1:0] in TMRx\_CTRL1 register
- Select internal trigger by setting STIS[2:0]= 3'b000~3'b011 in TMRx\_STCTRL register
- Select external clock mode A by setting SMSEL[2:0]=3'b111 in TMRx\_STCTRL register
- Enable TMRx to start counting through the TMREN in TMRx\_CTRL1 register

Table 15-12 TMRx internal trigger connection

| Slave timer | IS0 (STIS=000) | IS1 (STIS=001) | IS2 (STIS=010) | IS3 (STIS=011) |
|-------------|----------------|----------------|----------------|----------------|
| TMR1        | TMR9           | TMR2           | TMR3           | TMR4           |

Figure 15-91 Counter timing with prescaler value changing from 0 to 3

**15.5.3.2 Counting mode**

The advanced-control timer consists of a 16-bit counter supporting up, down, up/down counting modes.

The TMRx\_PR register is used to define counting period of counter. The value in the TMRx\_PR is immediately moved to the shadow register by default. When the periodic buffer is enabled (PRBEN=1), the value in the TMRx\_PR register is transferred to the shadow register only at an overflow event.

TMRx\_DIV register is used to define the counter frequency of the counter. The counter counts once

every DIV[15:0]+1 clock cycle. The value of the TMRx\_DIV register are transferred into the shadow register at each overflow event.

Reading the TMRx\_CNT register returns the current counter value. Writing the TMRx\_CNT register will update the current counter value.

An overflow event is enabled by default. It can be disabled by setting OVFEN=1 in the TMRx\_CTRL1 register. The OVFS bit in the TMRx\_CTRL1 register is used to select the source of an overflow event, which is, by default, counter overflow or underflow, setting OVFSWTR, reset signal generated by slave mode timer controller in reset mode. Once the OVFS is set, an overflow event is generated only when overflow or underflow occurs.

Setting the TMREN bit (TMREN=1) enables the timer to start counting. Base on synchronization logic, however, the actual enable signal TMR\_EN is set 1 clock cycle after the TMREN is set.

Figure 15-92 Basic structure of a counter



### Upcounting mode

This mode is enabled by setting TWCSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register. In upcounting mode, the counter counts from 0 to the value programmed in the TMR1\_PR register, restarts from 0, and generates a counter overflow event, with setting OVFIF bit to 1. If the overflow event is disabled, the counter is no longer reloaded with the prescaler and re-loaded value on counter overflow; otherwise, the prescaler and re-loaded value will be updated on an overflow event.

Figure 15-93 Overflow event when PRBEN=0



Figure 15-94 Overflow event when PRBEN=1



### Downcounting mode

This mode is enabled by setting TWCSEL[1:0]=2'b00 and OWCDIR=1'b1 in the TMRx\_CTRL1 register. In downcounting mode, the counter counts from the value programmed in the TMRx\_PR register down to 0, and restarts from the value programmed in the TMRx\_PR register, and generates a counter underflow event.

Figure 15-95 Counter timing diagram with internal clock divided by 3



### Up/down counting mode (center-aligned mode)

Up/down counting mode can be enabled by setting TWCMSEL[1:0]=2'b00 in the TMRx\_CTRL1 register. In up/down counting mode, the counter counts up/down alternatively. When the counter counts from the value programmed in the TMRx\_PR register down to 1, an underflow event is generated, and then restarts counting from 0; when the counter counts from 0 to the value of the TMRx\_PR register -1, an overflow event is generated, and then restarts counting from the value of the TMRx\_PR register. The OWCDIR bit indicates the current counting direction.

The TWCMSEL[1:0] bit in the TMRx\_CTRL1 register is used to select the condition under which the CxIF flag is set in two-way counting mode. In other words, when TWCMSEL[1:0]=2'b01 (counting mode 1) is selected, the CxIF flag is set only when the counter counts down; when TWCMSEL[1:0]=2'b10 (counting mode 2) is selected, the CxIF flag is set only when the counter counts up; when TWCMSEL[1:0]=2'b11 (counting mode 3) is selected, the CxIF flag is set when the counter counts up and down.

*Note: The OWCDIR is read-only in up/down counting mode.*

Figure 15-96 Counter timing diagram with internal clock divided by 0 and TMRx\_PR=0x32



### Repetition counter mode:

The TMRx\_RPR register is used to set repetition counting mode. This mode is enabled when the repetition counter value is not equal to 0. In this mode, an overflow event is generated when a counter overflow occurs ( $RPR[15:0]+1$ ). The repetition counter is decremented at each counter overflow. An overflow event is generated when the repetition counter reaches 0. The frequency of the overflow event can be adjusted by setting the repetition counter value.

Figure 15-97 OVFIF behavior in upcounting mode and center-aligned mode

**Encoder interface mode**

In this mode, the two inputs (TMRx\_CH1/ TMRx\_CH2) are required. Depending on the level on one input, the counter counts up or down on the edge of the other input. The OWCDIR bit indicates the direction of the counter, as shown in the figure below:

Figure 15-98 Structure of encoder mode



**Encoder mode A:** SMSEL=3'b001. The counter counts on the selected C1IFP1 edge (rising and falling edges), and the counting direction is dependent on the edge direction of C1IFP1 and the level of C2IFP2.

**Encoder mode B:** SMSEL=3'b010. The counter counts on the selected C2IFP2 edge (rising and falling edges), and the counting direction is dependent on the edge direction of C2IFP2 and the level of C1IFP1.

**Encoder mode C:** SMSEL=3'b011. The counter counts on both C1IFP1 and C2IFP2 edges (rising and falling edges). The counting direction is dependent on the C1IFP1 edge direction and C2IFP2 level, and C2IFP2 edge direction and C1IFP1 level.

To use encoder mode, follow the procedures below:

- Set channel 1 input signal filtering through the C1DF[3:0] bit in the TMRx\_CM1 register;
- Set channel 1 input signal active level through the C1P bit in the TMRx\_CCTRL register
- Set channel 2 input signal filtering through the C2DF[3:0] bit in the TMRx\_CM1 register;
- Set channel 2 input signal active level through the C2P bit in the TMRx\_CCTRL register
- Set channel 1 as input mode through the C1C[1:0] bit in the TMRx\_CM1 register;
- Set channel 2 as input mode through the C2C[1:0] bit in the TMRx\_CM1 register
- Select encoder mode A (SMSEL=3'b001), encoder mode B (SMSEL=3'b010), or encoder mode C (SMSEL=3'b011) by setting the SMSEL[2:0] bit in the TMRx\_STCTRL register
- Set counting cycles through the PR[15:0] bit in the TMRx\_PR register
- Set counting frequency through the DIV[15:0] bit in the TMRx\_DIV register
- Configure the corresponding IOs of TMRx\_CH1 and TMRx\_CH2 as multiplexed mode
- Enable counter through the TMREN bit in the TMRx\_CTRL1 register

Table 15-13 Counting direction versus encoder signals

| Active edge                        | Level on opposite signal<br>(C1IFP1 to C2IFP2, C2IFP2<br>to C1IFP1) | C1IFP1 signal |          | C2IFP2 signal |          |
|------------------------------------|---------------------------------------------------------------------|---------------|----------|---------------|----------|
|                                    |                                                                     | Rising        | Falling  | Rising        | Falling  |
| Count on C1IFP1 only               | High                                                                | Down          | Up       | No count      | No count |
|                                    | Low                                                                 | Up            | Down     | No count      | No count |
| Count on C2IFP2 only               | High                                                                | No count      | No count | Up            | Down     |
|                                    | Low                                                                 | No count      | No count | Down          | Up       |
| Count on both C1IFP1<br>and C2IFP2 | High                                                                | Down          | Up       | Up            | Down     |
|                                    | Low                                                                 | Up            | Down     | Down          | Up       |

Figure 15-99 Example of encoder interface mode C



### 15.5.3.3 TMR input function

The TMR1 has four independent channels. Each channel can be configured as input or output. As input, each channel input signal is processed as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. The C1INSE bit is used to select TMRx\_CHx, or the XOR-ed TMRx\_CH1, TMRx\_CH2 and TMRx\_CH3 as the source of C1IRAW.
- The sources of C2IRAW, C3IRAW and C4IRAW are TMRx\_CH2, TMRx\_CH3, TMRx\_CH4, respectively.
- CxIRAW goes through digital filter and generates the filtered CxIF signal. The digital filter uses the CxDF bit to program sampling frequency and sampling times.
- CxIF goes through edge detector, and generates the CxIFPx signal after edge selection. The edge selection depends on both CxP and CxCp bits. It is possible to select input rising edge, falling edge or both edges.
- CxIFPx goes through capture signal selector, and generates the CxIN signal after capture signal selection. The capture signal selection is defined by CxC bits. It is possible to select CxIFPx, CyIFPx or STCI as CxIN source. Of those, CyIFPx ( $x \neq y$ ) is the CyIFPy signal that is from Y channel and processed by channel-x edge detector (for example, C1IFP2 is the C1IFP1 signal that is from channel 1 and processed by channel 2 edge detector). The STCI comes from slave timer controller, and its source is selected by STIS bit.
- CxIN goes through input divider and generates the CxIPS signal. The divider factor can be defined as No division, /2, /4 or /8, by the CxIDIV bit.

Figure 15-100 Input/output channel 1 main circuit



Figure 15-101 Channel 1 input stage



#### Input mode

In input mode, the TMRx\_CxDT registers latch the current counter values after the selected trigger signal is detected, and the capture compare interrupt flag bit (CxIF) is set to 1. An interrupt/DMA request will be generated if the CxIEN bit and CxDEN bit are enabled. If the selected trigger signal is detected when the CxIF is set to 1, a capture overflow event is generated. The previous counter value will be overwritten

with the current counter value, and the CxRF is set to 1.

To capture the rising edge of C1IN input, following the procedure below:

- Set C1C=01 in the TMR1\_CM1 register to select the C1IN as channel 1 input
- Set C1IN signal filter bandwidth (CxDF[3: 0])
- Set the active edge on the C1IN channel by writing C1P=0 (rising edge) in the TMR1\_CCTRL register
- Program C1IN signal capture frequency divider (C1DIV[1: 0])
- Enable channel 1 input capture (C1EN=1)
- If needed, enable the relevant interrupt or DMA request by setting the C1IEN bit in the TMRx\_IDEN register or the C1DEN bit in the TMRx\_IDEN register

#### Timer Input XOR function

The timer input pins (TMR1\_CH1, TMR1\_CH2 and TMR1\_CH3) are connected to the channel 1 (selected by setting the C1INSE in the TMR1\_CTRL2 register) through an XOR gate.

The XOR gate can be used to connect Hall sensors. For example, connect the three XOR inputs to the three Hall sensors respectively so as to calculate the position and speed of the rotation by analyzing three Hall sensor signals.

#### PWM input

PWM input mode is applied to channel 1 and 2. To use this mode, both C1IN and C2IN are mapped on the same TMRx\_CHx, and the CxIFPx of either channel 1 or channel 2 must be configured as trigger input and slave mode controller is configured in reset mode.

The PWM input mode can be used to measure the period and duty cycle of the PWM input signal. For example, the user can measure the period and duty cycle of the PWM applied on channel 1 using the following procedures:

- Set C1C=2'b01: select C1IN for C1IFP1
- Set C1P=1'b0, select C1IFP1 rising edge active
- Set C2C=2'b10, select C2IN for C1IFP2
- Set C2P=1'b1, select C1IFP2 falling edge active
- Set STIS=3'b101, select the slave mode timer trigger signal as C1IFP1
- Set SMSEL=3'b100: configure the slave mode controller in reset mode
- Set C1EN=1'b1 and C2EN=1'b1. Enable channel 1 and input capture

After above configuration, the rising edge of channel 1 input signal will trigger the capture and stores the capture value into C1DT register, and it will reset the counter at the same time. The falling edge of the channel 1 input signal triggers the capture and stores the capture value into C2DT register. The period of the channel 1 input signal is calculated through C1DT, and its duty cycle through C2DT.

Figure 15-102 PWM input mode configuration example



Figure 15-103 PWM input mode



#### 15.5.3.4 TMR output function

The TMR output consists of a comparator and an output controller. It is used to program the period, duty cycle and polarity of the output signal. The advanced-control timer output function varies from one channel to one channel.

Figure 15-104 Channel output stage (channel 1 to 3)



Figure 15-105 Channel 4 output stage



#### Output mode

Write  $CxO[1:0] \neq 2'b00$  to configure the channel as output to implement multiple output modes. In this case, the counter value is compared with the value in the  $TMRx\_CxDT$  register, and the intermediate signal  $CxORAW$  is generated according to the output mode selected by  $CxOCTRL[2:0]$ , which is sent to IO after being processed by the output control circuit. The period of the output signal is configured by the  $TMRx\_PR$  register, while the duty cycle by the  $TMRx\_CxDT$  register.

Output compare modes include:

**PWM mode A:**

Enable PWM mode A by setting CxOCTRL=3'b110. In upcounting mode, C1ORAW outputs high when TMRx\_C1DT>TMRx\_CVAL; otherwise, it is low. In downcounting mode, C1ORAW outputs low when TMRx\_C1DT<TMRx\_CVAL; otherwise, it is high. Figure 15-105 presents an example of PWM mode A in upcounting mode, PR=0x32, and CxDT with different values.

To use PWM mode A, the following procedures are recommended:

- Set PWM periods through TMRx\_PR register
- Set PWM duty cycles through TMRx\_CxD
- Select PWM mode A by setting CxOCTRL=3'b110 in the TMRx\_CM1/CM2 register
- Set counting frequency through TMRx\_DIV register
- Select counting mode by setting the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register
- Select output polarity through the CxP and CxCp bits in the TMRx\_CCTRL register
- Enable channel output through the CxEN and CxCEN bits in the TMRx\_CCTRL register
- Enable TMRx output through the OEN bit in the TMRx\_BRK register
- Configure GPIOs corresponding to TMR output channels as multiplexed mode
- Enable TMRx to start counting through the TMREN bit in the TMRx\_CTRL1 register.

Figure 15-106 PWM mode A in upcounting mode

**PWM mode B:**

Enable PWM mode B by setting CxOCTRL=3'b111. In upcounting mode, C1ORAW outputs low when TMRx\_C1DT>TMRx\_CVAL; otherwise, it is high. In downcounting mode, C1ORAW outputs high when TMRx\_C1DT<TMRx\_CVAL; otherwise, it is low. Figure 15-106 presents an example of PWM mode B in up/downcounting mode, PR=0x32, and CxDT with different values.

Figure 15-107 PWM mode B in up/down counting mode

**Forced output mode:**

Enable forced output mode by setting CxOCTRL=3'b100/101. In this case, the CxORAW is forced to be the programmed level, regardless of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.

**Output compare mode:**

Enable output compare mode by setting CxOCTRL=3'b001/010/011. In this case, when the counter value matches the value of the CxDT register, the CxORAW is forced high (CxOCTRL=3'b001), low (CxOCTRL=3'b010) or toggling (CxOCTRL=3'b011). Figure 15-107 presents an example of output compare mode, C1DT=0x3. When the counter value is 0x3, C1OUT toggles.

Figure 15-108 C1ORAW toggles when counter value matches C1DT value

**One-pulse mode:**

This is a particular case of PWM mode. Enable one-pulse by setting OCMEN=1. In this mode, the comparison match is performed in the current counting period. The TMREN bit is cleared as soon as the current counting is completed. Therefore, only one pulse is output. When in upcounting mode, the configuration must follow the rule: CVAL<CxDT≤PR; in downcounting mode, CVAL>CxDT is required. Figure 15-108 presents an example of PWM B in upcounting mode & one-pulse mode. The counter counts a single cycle, and only a single pulse is output during this cycle.

Figure 15-109 One-pulse mode

**Fast output mode:**

Enable this mode by setting CxOIEN=1. If enabled, the CxORAW signal will not change when the counter value matches the CxDT, but change at the beginning of the current counting period. In other words, the comparison result is advanced, so the comparison result between the counter value and the TMRx\_CxDT register will determine the level of CxORAW in advance.

**Master mode timer event output**

When TMR is used as a master timer, one of the following source of signals can be selected as TRGOUT output to a slave mode timer. This is done by setting the PTOS bit in the TMRx\_CTRL2 register.

- PTOS=3'b000, TRGOUT output software overflow event (OVFSWTR bit in TMRx\_SWEVT register) or reset event
- PTOS=3'b001, TRGOUT output counter enable
- PTOS=3'b010, TRGOUT output counter overflow event
- PTOS=3'b011, TRGOUT output capture and compare event (C1DT)
- PTOS=3'b100, TRGOUT output C1ORAW
- PTOS=3'b101, TRGOUT output C2ORAW
- PTOS=3'b110, TRGOUT output C3ORAW
- PTOS=3'b111, TRGOUT output C4ORAW

**CxORAW clear**

When the CxOSEN bit is set, the CxORAW signal for a given channel is cleared by applying a high level to the EXT input. The CxORAW signal remains unchanged until the next overflow event.

This function can only be used in output capture or PWM modes, and does not work in forced output mode. [Figure 15-110](#) shows the example of clearing CxORAW. When the EXT input is high, the CxORAW signal, which was originally high, is driven low; when the EXT is low, the CxORAW signal outputs the corresponding level according to the comparison result between the counter value and CxDT value.

Figure 15-110 Clearing CxORAW (PWM mode B) by EXT input

**Dead-time insertion**

The channel 1 to 3 of the advanced-control timers contains a set of reverse channel output. This function is enabled by the CxCEN bit and its polarity is defined by CxCP. Refer to Table 15-15 for more information about the output state of CxOUT and CxCOUT.

The dead-time is activated when switching to IDLEF state (OEN falling down to 0).

Setting both CxEN and CxCEN bits, and using DTC[7:0] bit to insert dead-time of different durations. After the dead-time insertion, the rising edge of the CxOUT is delayed compared to the rising edge of the reference signal; the rising edge of the CxCOUT is delayed compared to the falling edge of the reference signal.

If the delay is greater than the width of the active output, then the C1OUT and C1COUT will not generate corresponding pulses. Therefore the dead-time should be less than the width of the active output.

[Figure 15-111](#) gives an example of dead-time insertion when CxP=0, CxCP=0, OEN=1, CxEN=1 and CxCEN=1.

Figure 15-111 Complementary output with dead-time insertion



### 15.5.3.5 TMR brake function

When the brake function is enabled (BRKEN=1), the CxOUT and CxCOUT are jointly controlled by OEN, FCSODIS, FCSOEN, CxIOS and CxCIOS. But, CxOUT and CxCOUT cannot be set both to active level at the same time. Please refer to 14-14 for more details.

The brake source can be the brake input pin or a clock failure event. The polarity is controlled by the BRKV bit.

When a brake event occurs, there are the following actions:

- The OEN bit is cleared asynchronously, and the channel output state is selected by setting the FCSODIS bit. This function works even if the MCU oscillator is off.
  - Once OEN=0, the channel output level is defined by the CxIOS bit. If FCSODIS=0, the timer output is disabled; otherwise, the output enable remains high.
  - When complementary outputs are used:
    - The outputs are first put in reset state, that is, inactive state (depending on the polarity). This is done asynchronously so that it works even if no clock is provided to the timer.
    - If the timer clock is still active, then the dead-time generator is activated. The CxIOS and CxCIOS bits are used to program the level after dead-time. Even in this case, the CxIOS and CxCIOS cannot be driven to their active level at the same time.
- Note: because of synchronization on OEN, the dead-time duration is usually longer than usual (around 2 *tmr\_clk* clock cycles)

- If FCSODIS=0, the timer releases the enable output; otherwise, it keeps the enable output; the enable output becomes high as soon as one of the CxEN and CxCEN bits becomes high.
- If the brake interrupt or DMA request is enabled, the brake status flag is set, and a brake interrupt or DMA request can be generated.
- If AOEN=1, the OEN bit is automatically set again at the next overflow event.

*Note: When the brake input is active, the OEN cannot be set, nor the status flag, BRKIF can be cleared.*

Figure 15-112 TMR output control



Figure 15-113 Example of TMR brake function



### 15.5.3.6 TMR synchronization

The timers are linked together internally for timer synchronization. Master timer is selected by setting the PTOS[2: 0] bit; Slave timer is selected by setting the SMSEL[2: 0] bit.

Slave modes include:

#### Slave mode: Reset mode

The counter and its prescaler can be reset by a selected trigger signal. An overflow event can be generated when OVFS=0.

Figure 15-114 Example of reset mode

**Slave mode: Suspend mode**

In this mode, the counter is controlled by a selected trigger input. The counter starts counting when the trigger input is high and stops as soon as the trigger input is low.

Figure 15-115 Example of suspend mode

**Slave mode: Trigger mode**

The counter can start counting on the rising edge of a selected trigger input (TMR\_EN=1).

Figure 15-116 Example of trigger mode



For more examples on timer synchronization, please refer to section 15.2.3.5.

### 15.5.3.7 TMR DMA

TMR has the following events for DMA transfer request: overflow event DMA request, trigger event DMA request, Hall sensor DMA request and channel event DMA request. It is possible to enable DMA request by setting the TMRx\_IDEN register. Once enabled, upon an event generated, a DMA request is triggered and output to the DMA peripheral.

#### TMR DMA Burst feature

TMR also supports TMR DMA Burst feature. Thanks to this feature, DMA can be triggered to rewrite multiple TMR consecutive registers by enabling a certain DMA request through the TMRx\_IDEN register.

As an overflow event to trigger TMR DMA Burst as an example:

- Enable overflow event to trigger DMA request using the OVFDEN bit in the TMRx\_IDEN register
- Configure Burst transfer times using the DTB bit in the TMRx\_DMACTRL register
- Configure the start address of Burst transfer using the ADDR bit in the TMRx\_DMACTRL register
- Enable counter

After the above-mentioned configurations, here is the whole process of TMR DMA Burst transfer:

Upon an overflow event, the TMR will send a DMA request to the DMA peripheral. Then the DMA writes the data into the TMRx\_DMADT register as requested. Inside TMR, the DMADT bit data is written into the start address register of Burst transfer and an ACK single is sent to TMR. After receiving this ACK, the TMR clears the current DMA request; when the Burst transfer is detected by the TMR not to complete fully, a new overflow event for DMA request is released to the DMA so that the DMA writes the requested data into the TMRx\_DMADT again. In this case, inside tmr, the DMADT register data is written into the Burst transfer start address + 0x4 address register, and a new ACK is sent to TMR, and so on, and so on, until the last operation of Burst transfer. When a full Burst transfer is complete, the REQ for overflow event DMA request would not be set any more until the next overflow event.

*Note: when using TMR DMA Burst feature, an empty register is prohibited and the TMRx\_DMACTRL as well as TMRx\_DMADT registers should not be available during the period from the start address to the end address.*

### 15.5.3.8 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the TMR1 counter stops counting by setting the TMR1\_PAUSE in the DEBUG module.

## 15.5.4 TMR1 registers

These peripheral registers have to be accessed by half words (16 bits) or words (32 bits).

Table 15-14 TMR1 register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| TMR1_CTRL1  | 0x00   | 0x0000 0000 |
| TMR1_CTRL2  | 0x04   | 0x0000 0000 |
| TMR1_STCTRL | 0x08   | 0x0000 0000 |
| TMR1_IDEN   | 0x0C   | 0x0000 0000 |
| TMR1ISTS    | 0x10   | 0x0000 0000 |
| TMR1_SWEVT  | 0x14   | 0x0000 0000 |
| TMR1_CM1    | 0x18   | 0x0000 0000 |
| TMR1_CM2    | 0x1C   | 0x0000 0000 |
| TMR1_CCTRL  | 0x20   | 0x0000 0000 |
| TMR1_CVAL   | 0x24   | 0x0000 0000 |
| TMR1_DIV    | 0x28   | 0x0000 0000 |
| TMR1_PR     | 0x2C   | 0x0000 FFFF |
| TMR1_RPR    | 0x30   | 0x0000 0000 |
| TMR1_C1DT   | 0x34   | 0x0000 0000 |

|              |      |             |
|--------------|------|-------------|
| TMR1_C2DT    | 0x38 | 0x0000 0000 |
| TMR1_C3DT    | 0x3C | 0x0000 0000 |
| TMR1_C4DT    | 0x40 | 0x0000 0000 |
| TMR1_BRK     | 0x44 | 0x0000 0000 |
| TMR1_DMACTRL | 0x48 | 0x0000 0000 |
| TMR1_DMADT   | 0x4C | 0x0000 0000 |

#### 15.5.4.1 TMR1 control register 1 (TMR1\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | <p>Clock division<br/>This field is used to define the division ratio between digital filter sampling frequency (<math>f_{DTS}</math>) and timer clock frequency (<math>f_{CK\_INT}</math>). It is also used to set the division ratio between dead time base (<math>T_{DTS}</math>) and timer clock period (<math>T_{CK\_INT}</math>)</p> <ul style="list-style-type: none"> <li>00: No division, <math>f_{DTS}=f_{CK\_INT}</math></li> <li>01: Divided by 2, <math>f_{DTS}=f_{CK\_INT}/2</math></li> <li>10: Divided by 4, <math>f_{DTS}=f_{CK\_INT}/4</math></li> <li>11: Reserved</li> </ul> |
| Bit 7      | PRBEN    | 0x0         | rw   | <p>Period buffer enable<br/>0: Period buffer is disabled<br/>1: Period buffer is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 6: 5   | TWCMSEL  | 0x0         | rw   | <p>Two-way counting mode selection<br/>00: One-way counting mode, depending on the OWCDIR bit<br/>01: Central-aligned counting mode 1, The counter counts up and down alternately, the CxIF bit is set only when the counter is counting down<br/>10: Central-aligned counting mode 2, The counter counts up and down alternately, the CxIF bit is set only when the counter is counting up<br/>11: Central-aligned counting mode 3, The counter counts up and down alternately, the CxIF bit is set when the counter is counting up or down</p>                                                 |
| Bit 4      | OWCDIR   | 0x0         | rw   | <p>One-way count direction<br/>0: Up<br/>1: Down</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3      | OCMEN    | 0x0         | rw   | <p>One cycle mode enable<br/>This bit is used to select whether to stop counting at an update event<br/>0: The counter does not stop at an update event<br/>1: The counter stops at an update event</p>                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 2      | OVFS     | 0x0         | rw   | <p>Overflow event source<br/>This bit is used to select overflow event or DMA request sources.<br/>0: Counter overflow, setting the OVFSWTR bit or overflow event generated by slave timer controller<br/>1: Only counter overflow generates an overflow event</p>                                                                                                                                                                                                                                                                                                                               |
| Bit 1      | OVFEN    | 0x0         | rw   | <p>Overflow event enable<br/>0: Enabled<br/>1: Disabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 0      | TMREN    | 0x0         | rw   | <p>TMR enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 15.5.4.2 TMR1 control register 2 (TMR1\_CTRL2)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 15 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                                                                                                                           |
| Bit 14     | C4IOS    | 0x0         | rw   | Channel 4 idle output state                                                                                                                                                                                                                                                                      |
| Bit 13     | C3CIOS   | 0x0         | rw   | Channel 3 complementary idle output state                                                                                                                                                                                                                                                        |
| Bit 12     | C3IOS    | 0x0         | rw   | Channel 3 idle output state                                                                                                                                                                                                                                                                      |
| Bit 11     | C2CIOS   | 0x0         | rw   | Channel 2 complementary idle output state                                                                                                                                                                                                                                                        |
| Bit 10     | C2IOS    | 0x0         | rw   | Channel 2 idle output state                                                                                                                                                                                                                                                                      |
| Bit 9      | C1CIOS   | 0x0         | rw   | Channel 1 complementary idle output state<br>Output disabled (OEN = 0), after dead-time:<br>0: C1OUTL=0<br>1: C1OUTL=1                                                                                                                                                                           |
| Bit 8      | C1IOS    | 0x0         | rw   | Channel 1 idle output state<br>Output disabled (OEN = 0), after dead-time:<br>0: C1OUT=0<br>1: C1OUT=1                                                                                                                                                                                           |
| Bit 7      | C1INSEL  | 0x0         | rw   | C1IN selection<br>0: CH1 pin is connected to C1IRAW input<br>1: The XOR result of CH1, CH2 and CH3 pins is connected to C1IRAW input                                                                                                                                                             |
| Bit 6: 4   | PTOS     | 0x0         | rw   | Master TMR output selection<br>This field is used to select the TMRx signal sent to the slave timer.<br>000: Reset<br>001: Enable<br>010: Update<br>011: Compare pulse (C1DT)<br>100: C1ORAW signal<br>101: C2ORAW signal<br>110: C3ORAW signal<br>111: C4ORAW signal                            |
| Bit 3      | DRS      | 0x0         | rw   | DMA request source<br>0: Capture/compare event<br>1: Overflow event                                                                                                                                                                                                                              |
| Bit 2      | CCFS     | 0x0         | rw   | Channel control bit flash selection<br>This bit only acts on channels that have complementary output. If the channel control bits are buffered:<br>0: Control bits are updated by setting the HALLSWTR bit<br>1: Control bits are updated by setting the HALLSWTR bit or a rising edge on TRGIN. |
| Bit 1      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                           |
| Bit 0      | CBCTRL   | 0x0         | rw   | Channel buffer control<br>This bit acts on channels that have complementary output.<br>0: CxEN, CxCEN and CxOCTRL bits are not buffered.<br>1: CxEN, CxCEN and CxOCTRL bits are buffered.<br>When CBCTRL="1". CxEN, CxCEN and CxOCTRL can be updated only upon a HALL event.                     |

### 15.5.4.3 TMR1 slave timer control register (TMR1\_STCTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                        |
| Bit 15     | ESP      | 0x0         | rw   | External signal polarity<br>0: High or rising edge<br>1: Low or falling edge                                  |
| Bit 14     | ECMBEN   | 0x0         | rw   | External clock mode B enable<br>This bit is used to enable external clock mode B<br>0: Disabled<br>1: Enabled |

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |     |      | External signal divide<br>This field is used to select the frequency division of an external trigger<br>00: Normal<br>01: Divided by 2<br>10: Divided by 4<br>11: Divided by 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 13: 12 | ESDIV    | 0x0 | rw   | External signal filter<br>This field is used to filter an external signal. The external signal can be sampled only after it has been generated N times<br>0000: No filter, sampling by $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
| Bit 11: 8  | ESF      | 0x0 | rw   | Subordinate TMR synchronization<br>If enabled, master and slave timer can be synchronized.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 7      | STS      | 0x0 | rw   | Subordinate TMR input selection<br>This field is used to select the subordinate TMR input.<br>000: Internal selection 0 (IS0)<br>001: Internal selection 1 (IS1)<br>010: Internal selection 2 (IS2)<br>011: Internal selection 3 (IS3)<br>100: C1IRAW input detector (C1INC)<br>101: Filtered input 1 (C1IF1)<br>110: Filtered input 2 (C1IF2)<br>111: External input (EXT)<br>Please refer to Table 15-12 for more information on ISx for each timer.                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3      | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 2: 0   | SMSEL    | 0x0 | rw   | Subordinate TMR mode selection<br>000: Slave mode is disabled<br>001: Encoder mode A<br>010: Encoder mode B<br>011: Encoder mode C<br>100: Reset mode — Rising edge of the TRGIN input reinitializes the counter<br>101: Suspend mode — The counter starts counting when the TRGIN is high<br>110: Trigger mode — A trigger event is generated at the rising edge of the TRGIN input<br>111: External clock mode A — Rising edge of the TRGIN input clocks the counter<br>Note: Please refer to count mode section for the details on encoder mode A/B/C.                                                                                                                                                                                                                                                                                                          |

#### 15.5.4.4 TMR1 DMA/interrupt enable register (TMR1\_IDEN)

| Bit       | Name     | Reset value | Type | Description                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------|
| Bit 31:15 | Reserved | 0x0 0000    | resd | Kept at default value.                                         |
| Bit 14    | TDEN     | 0x0         | rw   | Trigger DMA request enable<br>0: Disabled<br>1: Enabled        |
| Bit 13    | HALLDE   | 0x0         | rw   | HALL DMA request enable<br>0: Disabled<br>1: Enabled           |
| Bit 12    | C4DEN    | 0x0         | rw   | Channel 4 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 11    | C3DEN    | 0x0         | rw   | Channel 3 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 10    | C2DEN    | 0x0         | rw   | Channel 2 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 9     | C1DEN    | 0x0         | rw   | Channel 1 DMA request enable<br>0: Disabled<br>1: Enabled      |
| Bit 8     | OVFDEN   | 0x0         | rw   | Overflow event DMA request enable<br>0: Disabled<br>1: Enabled |
| Bit 7     | BRKIE    | 0x0         | rw   | Brake interrupt enable<br>0: Disabled<br>1: Enabled            |
| Bit 6     | TIEN     | 0x0         | rw   | Trigger interrupt enable<br>0: Disabled<br>1: Enabled          |
| Bit 5     | HALLIEN  | 0x0         | rw   | HALL interrupt enable<br>0: Disabled<br>1: Enabled             |
| Bit 4     | C4IEN    | 0x0         | rw   | Channel 4 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 3     | C3IEN    | 0x0         | rw   | Channel 3 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 2     | C2IEN    | 0x0         | rw   | Channel 2 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 1     | C1IEN    | 0x0         | rw   | Channel 1 interrupt enable<br>0: Disabled<br>1: Enabled        |
| Bit 0     | OVFIEN   | 0x0         | rw   | Overflow interrupt enable<br>0: Disabled<br>1: Enabled         |

#### 15.5.4.5 TMR1 interrupt status register (TMR1ISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                          |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 13 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                               |
| Bit 12     | C4RF     | 0x0         | rw0c | Channel 4 recapture flag<br>Please refer to C1RF description.                                                                                        |
| Bit 11     | C3RF     | 0x0         | rw0c | Channel 3 recapture flag<br>Please refer to C1RF description.                                                                                        |
| Bit 10     | C2RF     | 0x0         | rw0c | Channel 2 recapture flag<br>Please refer to C1RF description.                                                                                        |
| Bit 9      | C1RF     | 0x0         | rw0c | Channel 1 recapture flag<br>This bit indicates whether a recapture is detected when C1IF=1. This bit is set by hardware, and cleared by writing "0". |

|       |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 0: No capture is detected<br>1: Capture is detected.                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 8 | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 7 | BRKIF    | 0x0 | rw0c | Brake interrupt flag<br>This bit indicates whether the brake input is active or not.<br>It is set by hardware and cleared by writing "0"<br>0: Inactive level<br>1: Active level                                                                                                                                                                                                                                                                     |
| Bit 6 | TRGIF    | 0x0 | rw0c | Trigger interrupt flag<br>This bit is set by hardware on a trigger event. It is cleared by writing "0".<br>0: No trigger event occurs<br>1: Trigger event is generated.<br>Trigger event: an active edge is detected on TRGIN input, or any edge in suspend mode.                                                                                                                                                                                    |
| Bit 5 | HALLIF   | 0x0 | rw0c | HALL interrupt flag<br>This bit is set by hardware on HALL event. It is cleared by writing "0".<br>0: No Hall event occurs.<br>1: Hall event is detected.<br>HALL even: CxEN, CxCEN and CxOCTRL are updated.                                                                                                                                                                                                                                         |
| Bit 4 | C4IF     | 0x0 | rw0c | Channel 4 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 3 | C3IF     | 0x0 | rw0c | Channel 3 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 2 | C2IF     | 0x0 | rw0c | Channel 2 interrupt flag<br>Please refer to C1IF description.                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 1 | C1IF     | 0x0 | rw0c | Channel 1 interrupt flag<br>If the channel 1 is configured as input mode:<br>This bit is set by hardware on a capture event. It is cleared by software or read access to the TMRx_C1DT<br>0: No capture event occurs<br>1: Capture event is generated<br>If the channel 1 is configured as output mode:<br>This bit is set by hardware on a compare event. It is cleared by software.<br>0: No compare event occurs<br>1: Compare event is generated |
| Bit 0 | OVFIF    | 0x0 | rw0c | Overflow interrupt flag<br>This bit is set by hardware on an overflow event. It is cleared by software.<br>0: No overflow event occurs<br>1: Overflow event is generated. If OVFEN=0 and OVFS=0 in the TMRx_CTRL1 register:<br>– An overflow event is generated when OVFSWTR= 1 in the TMRx_SWEVT register;<br>– An overflow event is generated when the counter CVAL is reinitialized by a trigger event.                                           |

#### 15.5.4.6 TMR1 software event register (TMR1\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                     |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x00 0000   | resd | Kept at default value.                                                                                                                          |
| Bit 7     | BRKSWTR  | 0x0         | wo   | Brake event triggered by software<br>This bit is set by software to generate a brake event.<br>0: No effect<br>1: Generate a brake event.       |
| Bit 6     | TRGSWTR  | 0x0         | rw   | Trigger event triggered by software<br>This bit is set by software to generate a trigger event.<br>0: No effect<br>1: Generate a trigger event. |
| Bit 5     | HALLSWTR | 0x0         | wo   | HALL event triggered by software<br>This bit is set by software to generate a HALL event.<br>0: No effect<br>1: Generate a HALL event.          |

|       |         |     |    |                                                                                                                                                       |
|-------|---------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     |    | Note: This bit acts only on channels that have complementary output.                                                                                  |
| Bit 4 | C4SWTR  | 0x0 | wo | Channel 4 event triggered by software<br>Please refer to C1SWTR description.                                                                          |
| Bit 3 | C3SWTR  | 0x0 | wo | Channel 3 event triggered by software<br>Please refer to C1SWTR description.                                                                          |
| Bit 2 | C2SWTR  | 0x0 | wo | Channel 2 event triggered by software<br>Please refer to C1SWTR description                                                                           |
| Bit 1 | C1SWTR  | 0x0 | wo | Channel 1 event triggered by software<br>This bit is set by software to generate a channel 1 event.<br>0: No effect<br>1: Generate a channel 1 event. |
| Bit 0 | OVFSWTR | 0x0 | wo | Overflow event triggered by software<br>This bit is set by software to generate an overflow event.<br>0: No effect<br>1: Generate an overflow event.  |

### 15.5.4.7 TMR1 channel mode register1 (TMR1\_CM1)

The channel can be used in input (capture mode) or output (compare mode). The direction of a channel is defined by the corresponding CxC bits. All the other bits of this register have different functions in input and output modes. The CxOx describes its function in output mode when the channel is in output mode, while the Cxlx describes its function in output mode when the channel is in input mode. Attention must be given to the fact that the same bit can have different functions in input mode and output mode.

#### Output compare mode:

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 15     | C2OSEN   | 0x0         | rw   | Channel 2 output switch enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 14: 12 | C2OCTRL  | 0x0         | rw   | Channel 2 output control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 11     | C2OBEN   | 0x0         | rw   | Channel 2 output buffer enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 10     | C2OIEN   | 0x0         | rw   | Channel 2 output enable immediately                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|            |          |             |      | Channel 2 configuration<br>This field is used to define the direction of the channel 2 (input or output), and the selection of input pin when C2EN='0':<br>00: Output<br>01: Input, C2IN is mapped on C2IFP2<br>10: Input, C2IN is mapped on C1IFP2<br>11: Input, C2IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS register.                                                                                                                                                                 |
| Bit 9: 8   | C2C      | 0x0         | rw   | Channel 1 output switch enable<br>0: C1ORAW is not affected by EXT input.<br>1: Once a high level is detect on EXT input, clear C1ORAW.                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 7      | C1OSEN   | 0x0         | rw   | Channel 1 output control<br>This field defines the behavior of the original signal C1ORAW.<br>000: Disconnected. C1ORAW is disconnected from C1OUT;<br>001: C1ORAW is high when TMR1_CVAL=TMR1_C1DT<br>010: C1ORAW is low when TMR1_CVAL=TMR1_C1DT<br>011: Switch C1ORAW level when TMR1_CVAL=TMR1_C1DT<br>100: C1ORAW is forced low<br>101: C1ORAW is forced high.<br>110: PWM mode A<br>—OWCDIR=0, C1ORAW is high once TMR1_C1DT>TMR1_CVAL, else low;<br>—OWCDIR=1, C1ORAW is low once TMR1_C1DT <TMR1_CVAL, else high;<br>111: PWM mode B |
| Bit 6: 4   | C1OCTRL  | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|                                                                                                                                                                                 |          |             |      | <ul style="list-style-type: none"> <li>— OWCDIR=0, C1ORAW is low once TMR1_C1DT &gt;TMR1_CVAL, else high;</li> <li>— OWCDIR=1, C1ORAW is high once TMR1_C1DT &lt;TMR1_CVAL, else low.</li> </ul> <p><i>Note: In the configurations other than 000', the C1OUT is connected to C1ORAW. The C1OUT output level is not only subject to the changes of C1ORAW, but also the output polarity set by CCTRL.</i></p> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 3                                                                                                                                                                           | C1OBEN   | 0x0         | rw   | <p>Channel 1 output buffer enable</p> <p>0: Buffer function of TMRx_C1DT is disabled. The new value written to the TMRx_C1DT takes effect immediately.</p> <p>1: Buffer function of TMRx_C1DT is enabled. The value to be written to the TMRx_C1DT is stored in the buffer register, and can be sent to the TMRx_C1DT register only on an overflow event.</p>                                                 |
| Bit 2                                                                                                                                                                           | C1OIEN   | 0x0         | rw   | <p>Channel 1 output enable immediately</p> <p>In PWM mode A or B, this bit is used to accelerate the channel 1 output's response to the trigger event.</p> <p>0: Need to compare the CVAL with C1DT before generating an output</p> <p>1: No need to compare the CVAL and C1DT. An output is generated immediately when a trigger event occurs.</p>                                                           |
| Bit 1: 0                                                                                                                                                                        | C1C      | 0x0         | rw   | <p>Channel 1 configuration</p> <p>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':</p> <p>00: Output</p> <p>01: Input, C1IN is mapped on C1IFP1</p> <p>10: Input, C1IN is mapped on C2IFP1</p> <p>11: Input, C1IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.</p>                |
| <b>Input capture mode:</b>                                                                                                                                                      |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit                                                                                                                                                                             | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 31: 16                                                                                                                                                                      | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 15: 12                                                                                                                                                                      | C2DF     | 0x0         | rw   | Channel 2 digital filter                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 11: 10                                                                                                                                                                      | C2IDIV   | 0x0         | rw   | Channel 2 input divider                                                                                                                                                                                                                                                                                                                                                                                       |
| Channel 2 configuration                                                                                                                                                         |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| This field is used to define the direction of the channel 2 (input or output), and the selection of input pin when C2EN='0':                                                    |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 9: 8                                                                                                                                                                        | C2C      | 0x0         | rw   | <p>00: Output</p> <p>01: Input, C2IN is mapped on C2IFP2</p> <p>10: Input, C2IN is mapped on C1IFP2</p> <p>11: Input, C2IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.</p>                                                                                                                                                                                   |
| Channel 1 digital filter                                                                                                                                                        |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| This field is used to set the filter for channel 1. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output. |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0000: No filter, sampling is done at $f_{DTS}$                                                                                                                                  |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2                                                                                                                                        |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4                                                                                                                                        |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8                                                                                                                                        |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6                                                                                                                                          |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8                                                                                                                                          |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6                                                                                                                                          |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8                                                                                                                                          |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6                                                                                                                                          |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8                                                                                                                                          |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5                                                                                                                                         |          |             |      |                                                                                                                                                                                                                                                                                                                                                                                                               |

|          |        |     |    |                                                                                                                                                                                                                                                                                                                                                                        |
|----------|--------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |     |    | 1011: $f_{SAMPLING}=f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING}=f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING}=f_{DTS}/32$ , N=5<br>1110: $f_{SAMPLING}=f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING}=f_{DTS}/32$ , N=8                                                                                                                                                              |
| Bit 3: 2 | C1IDIV | 0x0 | rw | Channel 1 input divider<br>This field defines Channel 1 input divider.<br>00: No divider. An input capture is generated at each active edge.<br>01: An input compare is generated every 2 active edges<br>10: An input compare is generated every 4 active edges<br>11: An input compare is generated every 8 active edges<br>Note: the divider is reset once C1EN='0' |
| Bit 1: 0 | C1C    | 0x0 | rw | Channel 1 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C1EN='0':<br>00: Output<br>01: Input, C1IN is mapped on C1IFP1<br>10: Input, C1IN is mapped on C2IFP1<br>11: Input, C1IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS.    |

#### 15.5.4.8 TMR1 channel mode register 2 (TMR1\_CM2)

The channel can be used in input (capture mode) or output (compare mode). The direction of a channel is defined by the corresponding CxC bits. All the other bits of this register have different functions in input and output modes. The CxOx describes its function in output mode when the channel is in output mode, while the Cxlx describes its function in output mode when the channel is in input mode. Attention must be given to the fact that the same bit can have different functions in input mode and output mode.

##### Output compare mode:

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                   |
| Bit 15     | C4OSEN   | 0x0         | rw   | Channel 4 output switch enable                                                                                                                                                                                                                                                                                                           |
| Bit 14: 12 | C4OCTRL  | 0x0         | rw   | Channel 4 output control                                                                                                                                                                                                                                                                                                                 |
| Bit 11     | C4OBEN   | 0x0         | rw   | Channel 4 output buffer enable                                                                                                                                                                                                                                                                                                           |
| Bit 10     | C4OIEN   | 0x0         | rw   | Channel 4 output enable immediately                                                                                                                                                                                                                                                                                                      |
|            |          |             |      | Channel 4 configuration                                                                                                                                                                                                                                                                                                                  |
|            |          |             |      | This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C4EN='0':<br>00: Output<br>01: Input, C4IN is mapped on C4IFP4<br>10: Input, C4IN is mapped on C3IFP4<br>11: Input, C4IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |
| Bit 9: 8   | C4C      | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                          |
| Bit 7      | C3OSEN   | 0x0         | rw   | Channel 3 output switch enable                                                                                                                                                                                                                                                                                                           |
| Bit 6: 4   | C3OCTRL  | 0x0         | rw   | Channel 3 output control                                                                                                                                                                                                                                                                                                                 |
| Bit 3      | C3OBEN   | 0x0         | rw   | Channel 3 output buffer enable                                                                                                                                                                                                                                                                                                           |
| Bit 2      | C3OIEN   | 0x0         | rw   | Channel 3 output enable immediately                                                                                                                                                                                                                                                                                                      |
|            |          |             |      | Channel 3 configuration                                                                                                                                                                                                                                                                                                                  |
|            |          |             |      | This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C3EN='0':<br>00: Output<br>01: Input, C3IN is mapped on C3IFP3<br>10: Input, C3IN is mapped on C4IFP3<br>11: Input, C3IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |
| Bit 1: 0   | C3C      | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                          |

**Input capture mode:**

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                              |
| Bit 15: 12 | C4DF     | 0x0         | rw   | Channel 4 digital filter                                                                                                                                                                                                                                                                                                                                            |
| Bit 11: 10 | C4IDIV   | 0x0         | rw   | Channel 4 input divider                                                                                                                                                                                                                                                                                                                                             |
|            |          |             |      | Channel 4 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C4EN='0':<br>00: Output<br>01: Input, C4IN is mapped on C4IFP4<br>10: Input, C4IN is mapped on C3IFP4<br>11: Input, C4IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |
| Bit 9: 8   | C4C      | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 7: 4   | C3DF     | 0x0         | rw   | Channel 3 digital filter                                                                                                                                                                                                                                                                                                                                            |
| Bit 3: 2   | C3IDIV   | 0x0         | rw   | Channel 3 input divider                                                                                                                                                                                                                                                                                                                                             |
|            |          |             |      | Channel 3 configuration<br>This field is used to define the direction of the channel 1 (input or output), and the selection of input pin when C3EN='0':<br>00: Output<br>01: Input, C3IN is mapped on C3IFP3<br>10: Input, C3IN is mapped on C4IFP3<br>11: Input, C3IN is mapped on STCI. This mode works only when the internal trigger input is selected by STIS. |
| Bit 1:0    | C3C      | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                     |

**15.5.4.9 TMR1 channel control register (TMR1\_CCTRL)**

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                                                                                                            |
| Bit 13     | C4P      | 0x0         | rw   | Channel 4 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                            |
| Bit 12     | C4EN     | 0x0         | rw   | Channel 4 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                             |
| Bit 11     | C3CP     | 0x0         | rw   | Channel 3 complementary polarity<br>Please refer to C1P description.                                                                                                                                                                                                              |
| Bit 10     | C3CEN    | 0x0         | rw   | Channel 3 complementary enable<br>Please refer to C1EN description.                                                                                                                                                                                                               |
| Bit 9      | C3P      | 0x0         | rw   | Channel 3 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                            |
| Bit 8      | C3EN     | 0x0         | rw   | Channel 3 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                             |
| Bit 7      | C2CP     | 0x0         | rw   | Channel 2 complementary polarity<br>Please refer to C1P description.                                                                                                                                                                                                              |
| Bit 6      | C2CEN    | 0x0         | rw   | Channel 2 complementary enable<br>Please refer to C1EN description.                                                                                                                                                                                                               |
| Bit 5      | C2P      | 0x0         | rw   | Channel 2 polarity<br>Please refer to C1P description.                                                                                                                                                                                                                            |
| Bit 4      | C2EN     | 0x0         | rw   | Channel 2 enable<br>Please refer to C1EN description.                                                                                                                                                                                                                             |
| Bit 3      | C1CP     | 0x0         | rw   | Channel 1 complementary polarity<br>0: C1COUT is active high.<br>1: C1COUT is active low.                                                                                                                                                                                         |
| Bit 2      | C1CEN    | 0x0         | rw   | Channel 1 complementary enable<br>0: Output is disabled.<br>1: Output is enabled.                                                                                                                                                                                                 |
| Bit 1      | C1P      | 0x0         | rw   | Channel 1 polarity<br>When the channel 1 is configured as output mode:<br>0: C1OUT is active high<br>1: C1OUT is active low<br>When the channel 1 is configured as input mode:<br>0: C1IN active edge is on its rising edge. When used as external trigger, C1IN is not inverted. |

|      |      |     |    |                                                                                              |
|------|------|-----|----|----------------------------------------------------------------------------------------------|
|      |      |     |    | 1: C1IN active edge is on its falling edge. When used as external trigger, C1IN is inverted. |
| Bit0 | C1EN | 0x0 | rw | Channel 1 enable<br>0: Input or output is disabled<br>1: Input or output is enabled          |

Table 15-15 Complementary output channel CxOUT and CxCOUT control bits with brake function

| Control bit |             |            | Output state <sup>(1)</sup> |           |                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                   |
|-------------|-------------|------------|-----------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OEN bit     | FCSODIS bit | FCSOEN bit | CxEN bit                    | CxCEN bit | CxOUT output state                                                                                                                                                                                                                | CxCOUT output state                                                                                                                                                                                                               |
| 1           | X           | 0          | 0                           | 0         | Output disabled<br>(no driven by the timer)<br>CxOUT=0, Cx_EN=0                                                                                                                                                                   | Output disabled<br>(no driven by the timer)<br>CxOUT=0, CxCEN=0                                                                                                                                                                   |
|             |             | 0          | 0                           | 1         | Output disabled<br>(no driven by the timer)<br>CxOUT=0, Cx_EN=0                                                                                                                                                                   | CxORAW + polarity,<br>CxOUT= CxORAW xor<br>CxCP, CxCEN=1                                                                                                                                                                          |
|             |             | 0          | 1                           | 0         | CxORAW+ polarity<br>CxOUT= CxORAW xor CxP,<br>Cx_EN=1                                                                                                                                                                             | Output disabled<br>(no driven by the timer)<br>CxOUT=0, CxCEN=0                                                                                                                                                                   |
|             |             | 0          | 1                           | 1         | CxORAW+polarity+dead-<br>time,<br>Cx_EN=1                                                                                                                                                                                         | CxORAW<br>inverted+polarity+dead-<br>time,<br>CxCEN=1                                                                                                                                                                             |
|             |             | 1          | 0                           | 0         | Output disabled<br>(no driven by the timer)<br>CxOUT=CxP, Cx_EN=0                                                                                                                                                                 | Output disabled<br>(no driven by the timer)<br>CxOUT=CxP,<br>CxEN=0                                                                                                                                                               |
|             |             | 1          | 0                           | 1         | Off-state<br>(Output enabled with<br>inactive level)<br>CxOUT=CxP, Cx_EN=1                                                                                                                                                        | CxORAW + polarity,<br>CxOUT= CxORAW xor CxP,<br>CxEN=1                                                                                                                                                                            |
|             |             | 1          | 1                           | 0         | CxORAW + polarity,<br>CxOUT= CxORAW xor CxP,<br>Cx_EN=1                                                                                                                                                                           | Off-state<br>(Output enabled with<br>inactive level)<br>CxOUT=CxP,<br>CxEN=1                                                                                                                                                      |
|             |             | 1          | 1                           | 1         | CxORAW+ polarity+dead-<br>time, Cx_EN=1                                                                                                                                                                                           | CxORAW<br>inverted+polarity+dead-<br>time,<br>CxCEN=1                                                                                                                                                                             |
| 0           | X           | 0          | 0                           | 0         | Output disabled<br>(corresponding IO is not driven by the timer, IO<br>floating)                                                                                                                                                  | Output disabled<br>(corresponding IO is not driven by the timer, IO<br>floating)                                                                                                                                                  |
|             |             | 0          | 0                           | 1         | Asynchronously: CxOUT=CxP, Cx_EN=0,<br>CxOUT=CxP, CxCEN=0;                                                                                                                                                                        | Asynchronously: CxOUT=CxP, Cx_EN=0,<br>CxOUT=CxP, CxCEN=0;                                                                                                                                                                        |
|             |             | 0          | 1                           | 0         | If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level.                                                                | If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level.                                                                |
|             |             | 0          | 1                           | 1         | CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level.                                                                                                               | CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level.                                                                                                               |
|             |             | 1          | 0                           | 0         | CxEN=CxCEN=0: Output disabled<br>(corresponding IO is not driven by the timer, IO<br>floating)                                                                                                                                    | In other cases: Off-state (Output enabled with inactive<br>level)                                                                                                                                                                 |
|             |             | 1          | 0                           | 1         | Asynchronously: CxOUT =CxP, Cx_EN=1,<br>CxOUT=CxP, CxCEN=1;<br>If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level. | Asynchronously: CxOUT =CxP, Cx_EN=1,<br>CxOUT=CxP, CxCEN=1;<br>If the clock is present: after a dead-time,<br>CxOUT=CxIOS, CxCOUT=CxCIOS, assuming that<br>CxIOS and CxCIOS do not correspond to CxOUT and<br>CxOUT active level. |
|             |             | 1          | 1                           | 0         |                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                   |
|             |             | 1          | 1                           | 1         |                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                   |

Note: If the two outputs of a channel are not used (CxEN = CxCEN = 0), CxIOS, CxCIOS, CxP and CxCP must be cleared.

*Note: The state of the external I/O pins connected to the complementary CxOUT and CxCOUT channels depends on the CxOUT and CxCOUT channel state and the GPIO and the IOMUX registers.*

#### 15.5.4.10 TMR1 counter value register (TMR1\_CVAL)

| Bit        | Name     | Reset value | Type | Description            |
|------------|----------|-------------|------|------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value. |
| Bit 15: 0  | CVAL     | 0x0000      | rw   | Counter value          |

#### 15.5.4.11 TMR1 division value register (TMR1\_DIV)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                              |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                   |
| Bit 15: 0  | DIV      | 0x0000      | rw   | Divider value<br>The counter clock frequency $f_{CK\_CNT} = f_{TMR\_CLK} / (DIV[15:0]+1)$ .<br>The value of this register is transferred to the actual prescaler register when an overflow event occurs. |

#### 15.5.4.12 TMR1 period register (TMR1\_PR)

| Bit        | Name     | Reset value | Type | Description                                                                                                            |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                 |
| Bit 15: 0  | PR       | 0xFFFF      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

#### 15.5.4.13 TMR1 repetition period register (TMR1\_RPR)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                              |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                   |
| Bit 15: 0  | RPR      | 0x0000      | rw   | Repetition of period value<br>This field is used to reduce the generation rate of overflow events. An overflow event is generated when the repetition counter reaches 0. |

#### 15.5.4.14 TMR1 channel 1 data register (TMR1\_C1DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 15: 0  | C1DT     | 0x0000      | rw   | Channel 1 data register<br>When the channel 1 is configured as input mode:<br>The C1DT is the CVAL value stored by the last channel 1 input event (C1IN)<br>When the channel 1 is configured as output mode:<br>C1DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C1OBEN bit, and the corresponding output is generated on C1OUT as configured. |

#### 15.5.4.15 TMR1 channel 2 data register (TMR1\_C2DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 15: 0  | C2DT     | 0x0000      | rw   | Channel 2 data register<br>When the channel 2 is configured as input mode:<br>The C2DT is the CVAL value stored by the last channel 2 input event (C2IN).<br>When the channel 2 is configured as output mode:<br>C2DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C2OBEN bit, and the corresponding output is generated on C2OUT as configured. |

### 15.5.4.16 TMR1 channel 3 data register (TMR1\_C3DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.<br>Channel 3 data register<br>When the channel 3 is configured as input mode:<br>The C3DT is the CVAL value stored by the last channel 3 input event (C3IN).                                                                          |
| Bit 15: 0  | C3DT     | 0x0000      | rw   | When the channel 3 is configured as output mode:<br>C3DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C3OBEN bit, and the corresponding output is generated on C3OUT as configured. |

### 15.5.4.17 TMR1 channel 4 data register (TMRx\_C4DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.<br>Channel 4 data register<br>When the channel 4 is configured as input mode:<br>The C4DT is the CVAL value stored by the last channel 4 input event (C4IN).                                                                          |
| Bit 15: 0  | C4DT     | 0x0000      | rw   | When the channel 3 is configured as output mode:<br>C4DT is the value to be compared with the CVAL value.<br>Whether the written value takes effect immediately depends on the C4OBEN bit, and the corresponding output is generated on C4OUT as configured. |

### 15.5.4.18 TMR1 brake register (TMR1\_BRK)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x000       | resd | Kept at default value.<br>Brake input filter<br>This field is used to set the filter for brake input. "N" refers to the number of filtering, meaning that N consecutive events are needed to validate a transition on the output.<br>0000: No filter, sampling is done at $f_{DTS}$<br>0001: $f_{SAMPLING} = f_{CK\_INT}$ , N=2<br>0010: $f_{SAMPLING} = f_{CK\_INT}$ , N=4<br>0011: $f_{SAMPLING} = f_{CK\_INT}$ , N=8<br>0100: $f_{SAMPLING} = f_{DTS}/2$ , N=6<br>0101: $f_{SAMPLING} = f_{DTS}/2$ , N=8<br>0110: $f_{SAMPLING} = f_{DTS}/4$ , N=6<br>0111: $f_{SAMPLING} = f_{DTS}/4$ , N=8<br>1000: $f_{SAMPLING} = f_{DTS}/8$ , N=6<br>1001: $f_{SAMPLING} = f_{DTS}/8$ , N=8<br>1010: $f_{SAMPLING} = f_{DTS}/16$ , N=5<br>1011: $f_{SAMPLING} = f_{DTS}/16$ , N=6<br>1100: $f_{SAMPLING} = f_{DTS}/16$ , N=8<br>1101: $f_{SAMPLING} = f_{DTS}/32$ , N=5<br>1100: $f_{SAMPLING} = f_{DTS}/32$ , N=6<br>1111: $f_{SAMPLING} = f_{DTS}/32$ , N=8 |
| Bit 19: 16 | BKF      | 0x0         | rw   | Output enable<br>This bit acts on the channels as output. It is used to enable CxOUT and CxCOUT outputs.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 15     | OEN      | 0x0         | rw   | Automatic output enable<br>OEN is set automatically at an overflow event.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 14     | AOEN     | 0x0         | rw   | Brake input validity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 13     | BRKV     | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|          |         |      |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|---------|------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |         |      |    | This bit is used to select the active level of a brake input.<br>0: Brake input is active low.<br>1: Brake input is active high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 12   | BRKEN   | 0x0  | rw | Brake enable<br>This bit is used to enable brake input.<br>0: Brake input is disabled.<br>1: Brake input is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 11   | FCSOEN  | 0x0  | rw | Frozen channel status when holistic output enable<br>This bit acts on the channels that have complementary output. It is used to set the channel state when the timer is inactive and OEN=1.<br>0: CxOUT/CxCOUT outputs are disabled.<br>1: CxOUT/CxCOUT outputs are enabled. Output inactive level.                                                                                                                                                                                                                                                                                                                                                   |
| Bit 10   | FCSODIS | 0x0  | rw | Frozen channel status when holistic output disable<br>This bit acts on the channels that have complementary output. It is used to set the channel state when the timer is inactive and OEN=0.<br>0: CxOUT/CxCOUT outputs are disabled.<br>1: CxOUT/CxCOUT outputs are enabled. Output idle level.                                                                                                                                                                                                                                                                                                                                                      |
| Bit 9: 8 | WPC     | 0x0  | rw | Write protection configuration<br>This field is used to enable write protection.<br>00: Write protection is OFF.<br>01: Write protection level 3, and the following bits are write protected:<br>TMR1_BRK: BRKF, DTC, BRKEN, BRKV, and AOEN<br>TMR1_CTRL2: CxIOS and CxCIOS<br>10: Write protection level 2. The following bits and all bits in level 3 are write protected:<br>TMR1_CCTRL: CxP and CxCP<br>TMR1_BRK: FCSODIS and FCSOEN<br>11: Write protection level 1. The following bits and all bits in level 2 are write protected:<br>TMR1_CMx: CxOCTRL and CxOBEN<br>Note: Once WPC>0, its content remains frozen until the next system reset. |
| Bit 7: 0 | DTC     | 0x00 | rw | Dead-time configuration<br>This field defines the duration of the dead-time insertion. The 3-bit MSB of DTC[7: 0] is used for function selection:<br>0xx: DT = DTC [7: 0] * TDTS<br>10x: DT = (64+ DTC [5: 0]) * TDTS * 2<br>110: DT = (32+ DTC [4: 0]) * TDTS * 8<br>111: DT = (32+ DTC [4: 0]) * TDTS * 16                                                                                                                                                                                                                                                                                                                                           |

*Note: Based on lock configuration, BRKF, AOEN, BRKV, BRKEN, FCSODIS, FCSOEN and DTC[7:0] can all be write protected. But they must be configured when the first write access to the TMR1\_BRK register.*

#### 15.5.4.19 TMR1 DMA control register (TMR1\_DMACTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                       |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:13 | Reserved | 0x0 0000    | resd | Kept at default value.                                                                                                                                                                            |
| Bit 12:8  | DTB      | 0x00        | rw   | DMA transfer bytes<br>This field defines the number of DMA transfers:<br>00000: 1 byte      00001: 2 bytes<br>00010: 3 bytes      00011: 4 bytes<br>.....<br>10000: 17 bytes      10001: 18 bytes |
| Bit 7:5   | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                            |
| Bit 4: 0  | ADDR     | 0x00        | rw   | DMA transfer address offset<br>ADDR is defined as an offset starting from the address<br>of the TMRx_CTRL1 register:<br>00000: TMRx_CTRL1<br>00001: TMRx_CTRL2<br>00010: TMRx_STCTRL<br>.....     |

#### 15.5.4.20 TMR1 DMA data register (TMR1\_DMADT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                         |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                              |
| Bit 15: 0 | DMADT    | 0x0000      | rw   | DMA data register<br>A write/read operation to the DMADT register accesses<br>any TMR register located at the following address:<br>TMR1 peripheral address + ADDR*4 to TMR1 peripheral<br>address + ADDR*4 + DTB*4 |

## 16 Window watchdog timer (WWDT)

### 16.1 WWDT introduction

The window watchdog downcounter must be reloaded in a limited time window to prevent the watchdog circuits from triggering a system reset. The window watch dog is used to detect the occurrence of system malfunctions.

The window watchdog timer is clocked by a divided APB1\_CLK. The precision of the APB1\_CLK enables the window watchdog to take accurate control of the limited window.

### 16.2 WWDT main features

- 7-bit downcounter
- After the watchdog is enabled, a system reset is generated when the value of the downcounter is less than 0x40 or when the downcounter is reloaded outside the window.
- The downcounter can be reloaded by enabling the counter interrupt.

### 16.3 WWDT functional overview

If the watchdog is enabled, a system reset is generated at the following conditions:

- When the 7-bit downcounter scrolls from 0x40 to 0x3F;
- When the 7-bit downcounter is greater than the 7-bit window value programmed.

Figure 16-1 Window watchdog block diagram



To prevent system reset while reloading the counter value, the counter must be reloaded only when its value is less than the value stored in the window register and greater than 0x40.

The WWDT counter is clocked by a divided APB1\_CLK, with the division factor being defined by the DIV[1: 0] bit in the WWDT\_CFG register.

The counter value determines the maximum counter period before the watchdog generates a reset. It can be used together with the WIN[6: 0] bit to adjust the window value.

WWDT offers reload counter interrupt feature. If enabled, the WWDT will set the RLDF flag when the counter value reaches 0x40h, and an interrupt is generated accordingly. The interrupt service routine (ISTS) can be used to reload the counter to prevent a system reset. Note that if CNT[6]=0, setting the WWDTEN=1 will generate a system reset, so the CNT[6] bit must be always set (CNT[6]=1) while writing to the WWDT\_CTRL register to prevent the occurrence of an immediate reset once the window watchdog is enabled.

The formula to calculate the window watchdog time out:

$$T_{WWDT} = T_{PCLK1} \times 4096 \times 2^{DIV[1:0]} \times (CNT[5: 0] + 1); (\text{ms})$$

Where:  $T_{PCLK1}$  refers to APB1 clock period, in ms.

Table 16-1 Minimum and maximum timeout value when PCLK1=72 MHz

| Prescaler | Min. Timeout value | Max. Timeout value |
|-----------|--------------------|--------------------|
| 0         | 56.5μs             | 3.64ms             |
| 1         | 113.5μs            | 7.28ms             |
| 2         | 227.5μs            | 14.56ms            |
| 3         | 455μs              | 29.12ms            |

Figure 16-2 Window watchdog timing diagram



## 16.4 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the WWDT counter stops counting by setting the WWDT\_PAUSE in the DEBUG module.

## 16.5 WWDT registers

These peripheral registers must be accessed by half words (16 bits) or words (32 bits).

Table 16-2 WWDT register map and reset value

| Register  | Offset | Reset value |
|-----------|--------|-------------|
| WWDT_CTRL | 0x00   | 0x0000 007F |
| WWDT_CFG  | 0x04   | 0x0000 007F |
| WWDT_STS  | 0x08   | 0x0000 0000 |

### 16.5.1 Control register (WWDT\_CTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                              |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x000000    | resd | Kept at default value.                                                                                                   |
| Bit 7     | WWDTEN   | 0x0         | rw1s | Window watchdog enable<br>0: Disabled<br>1: Enabled<br>This bit is set by software, but can be cleared only after reset. |
| Bit 6: 0  | CNT      | 0x7F        | rw   | Downcounter<br>When the counter counts down to 0x3F, a reset is generated.                                               |

### 16.5.2 Configuration register (WWDT\_CFG)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                               |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x000000    | resd | Kept at default value.                                                                                                                                                                    |
| Bit 9      | RLDIEN   | 0x0         | rw1s | Reload counter interrupt<br>0: Disabled<br>1: Enabled                                                                                                                                     |
| Bit 8: 7   | DIV      | 0x0         | rw   | Clock division value<br>00: PCLK1 divided by 4096<br>01: PCLK1 divided by 8192<br>10: PCLK1 divided by 16384<br>11: PCLK1 divided by 32768                                                |
| Bit 6: 0   | WIN      | 0x7F        | rw   | Window value<br>If the counter is reloaded while its value is greater than the window register value, a reset will be generated. The counter must be reloaded between 0x40 and WIN[6: 0]. |

### 16.5.3 Status register (WWDT\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                  |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x0000 0000 | resd | Kept at default value.                                                                                                                       |
| Bit 0     | RLDIEN   | 0x0         | rw0c | Reload counter interrupt flag<br>This flag is set when the downcounter reaches 0x40.<br>This bit is set by hardware and cleared by software. |

# 17 Watchdog timer (WDT)

## 17.1 WDT introduction

The WDT is driven by a dedicated low-speed clock (LICK). Due to the lower clock accuracy of LICK, the WDT is best suited to the applications that have lower timing accuracy and can run independently outside the main application.

## 17.2 WDT main features

- 12-bit downcounter
- The counter is clocked by LICK (can work in Deepsleep and Standby modes)
- A system reset is generated under the following circumstances:
  - When the counter value is decremented to 0
  - When the counter is reloaded outside the window

## 17.3 WDT functional overview

### WDT enable:

Both software and hardware operations can be used to enable WDT. In other words, the WDT can be enabled by writing 0xCCCC to the WDT\_CMD register; or when the user enables the hardware watchdog through user system data area, the WDT will be automatically enabled after power-on reset.

### WDT reset:

When the counter value of the WDT counts down to 0, a WDT reset will be generated. Thus the WDT\_CMD register must be written with the value 0xAAAA at regular intervals to reload the counter value to avoid the WDT reset. Besides, setting WIN[11:0]= 0xFFFF (not default value) will enable window watchdog feature. In this case, when the counter value is greater than the window value, reloading counter value will trigger a system reset.

### WDT write-protected:

The WDT\_DIV, WDT\_RLD and WDT\_WIN registers are write-protected. Writing the value 0x5555 to the WDT\_CMD register will unlock write protection. The update status of these three registers are indicated by the DIVF, RLDF and WINF bits in the WDT\_STS register. If a different value is written to the WDT\_CMD register, these three registers will be re-protected. Writing the value 0xAAAA to the WDT\_CMD register also enables write protection.

### WDT clock:

The WDT counter is clocked by LICK. The LICK is an internal RC clock in the range of 30kHz~60kHz. Therefore, the timeout period is also within a certain range, so a margin should be taken into account when configuring timeout period. The LICK can be calibrated to obtain a relatively accurate WDT timeout. For more information about LICK, see the electrical characteristics section of the data sheet.

### WDT low power counting mode:

WDT can work in Sleep, Deepsleep and Standby modes. It is possible to stop counting in Deepsleep and Standby modes by setting the nWDT\_DEPSLP and nWDT\_STDBY bits in the User System Data area.

If the counter is disabled, it will stop decrementing as soon as the Deepsleep and Standby modes are entered. This means that the WDT would not generate a system reset in both low power modes. After waking up from these two modes, it continues downcounting from the value at the time of the entry of these modes.

Figure 17-1 WDT block diagram



Table 17-1 WDT timeout period (LICK=40kHz)

| Prescaler divider | DIV[2: 0] bits | Min.timeout (ms)<br>RLD[11: 0] = 0x000 | Max. timeout (ms)<br>RLD[11: 0] = 0xFFF |
|-------------------|----------------|----------------------------------------|-----------------------------------------|
| /4                | 0              | 0.1                                    | 409.6                                   |
| /8                | 1              | 0.2                                    | 819.2                                   |
| /16               | 2              | 0.4                                    | 1638.4                                  |
| /32               | 3              | 0.8                                    | 3276.8                                  |
| /64               | 4              | 1.6                                    | 6553.6                                  |
| /128              | 5              | 3.2                                    | 13107.2                                 |
| /256              | (6 or 7)       | 6.4                                    | 26214.4                                 |

## 17.4 Debug mode

When the microcontroller enters debug mode (Cortex®-M4F core halted), the WDT counter stops counting by setting the WDT\_PAUSE in the DEBUG module. Refer to Chapter 25.2 for more information.

## 17.5 WDT registers

These peripheral registers have to be accessed by half words (16 bits) or words (32 bits).

Table 17-2 WDT register and reset value

| Register | Offset | Reset value |
|----------|--------|-------------|
| WDT_CMD  | 0x00   | 0x0000 0000 |
| WDT_DIV  | 0x04   | 0x0000 0000 |
| WDT_RLD  | 0x08   | 0x0000 0FFF |
| WDT_STS  | 0x0C   | 0x0000 0000 |
| WDT_WIN  | 0x10   | 0x0000 0FFF |

### 17.5.1 Command register (WDT\_CMD)

(Reset in Standby mode)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                            |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                 |
| Bit 15: 0  | CMD      | 0x0000      | wo   | Command register<br>0xAAAA: Reload counter<br>0x5555: Unlock the write-protected WDT_DIV, WDT_RLD and WDT_WIN<br>0xCCCC: Enable WDT. If the hardware watchdog has been enabled, ignore this operation. |

### 17.5.2 Divider register (WDT\_DIV)

(Not reset in Standby mode)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved | 0x0000 0000 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                             |
| Bit 2: 0  | DIV      | 0x0         | rw   | Clock division value<br>000: LICK divided by 4<br>001: LICK divided by 8<br>010: LICK divided by 16<br>011: LICK divided by 32<br>100: LICK divided by 64<br>101: LICK divided by 128<br>110: LICK divided by 256<br>111: LICK divided by 256<br>The write protection must be unlocked in order to enable write access to the register. The register can be read only when DIVF=0. |

### 17.5.3 Reload register (WDT\_RLD)

(Not reset in Standby mode)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                       |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at default value.                                                                                                                            |
| Bit 11: 0  | RLD      | 0xFFFF      | rw   | Reload value<br>The write protection must be unlocked in order to enable write access to the register. The register can be read only when RLDF=0. |

### 17.5.4 Status register (WDT\_STS)

(Reset in Standby mode)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                         |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved | 0x0000 0000 | resd | Kept at default value.                                                                                                                                                              |
| Bit 2     | WINF     | 0x0         | ro   | Window value update complete flag<br>0: Window value update complete<br>1: Window value update is in process.<br>The WDT_WIN register can be written only when RLDF=0               |
| Bit 2     | RLDF     | 0x0         | ro   | Reload value update complete flag<br>0: Reload value update complete<br>1: Reload value update is in process.<br>The reload register WDT_RLD can be written only when RLDF=0        |
| Bit 0     | DIVF     | 0x0         | ro   | Division value update complete flag<br>0: Division value update complete<br>1: Division value update is in process.<br>The divider register WDT_DIV can be written only when DIVF=0 |

## 17.5.5 Window register (WDT\_WIN)

(Not reset in Standby mode)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at default value.                                                                                                                                                              |
| Bit 11: 0  | WIN      | 0xFFFF      | ro   | Window value<br>When the counter value is greater than the window value, reloading the counter will trigger a reset. The reload counter value falls between 0 and the window value. |

# 18 Enhanced real-time clock (ERTC)

## 18.1 ERTC introduction

The real-time clock provides a calendar clock function. The time and date can be modified by modifying the ERTC\_TIME and ERTC\_DATE register.

The ERTC module is in the battery powered domain, which means that it keeps running and free from the influence of system reset as long as VBAT is powered (VBAT must be supplied through VDD domain).

## 18.2 ERTC main features

- Real-time calendar, one alarm. Compensations for 28-, 29- (leap year), 30-, and 31-day months are performed. When the year register is a multiple of 4, it represents a leap year
- Periodic auto-wakeup
- Reference clock detection
- 2x programmable tamper detection supporting time stamp feature
- Supports fine calibration
- 20 x battery powered registers
- 5 x interrupts: alarm A, alarm B, periodic auto-wakeup, tamper detection and time stamp
- Multiplexed function output, calibration clock output, alarm event or wakeup event
- Multiplexed function input, reference clock input, two-channel tamper detection and time stamp

Figure 18-1 ERTC block diagram



## 18.3 ERTC functional overview

### 18.3.1 ERTC clocks

ERTC clock source (ERTC\_CLK) is selected via clock controller from a LEXT, LICK, and divided HEXT (by setting the ERTCSEL[1:0] in the CRM\_BPDC register).

The HEXT frequency division value is configured through the ERTC\_DIV[4:0] bit in CRM\_CFG register.

The ERTC embeds two dividers: A and B, selected by the DIVA[6: 0] and DIVB[14: 0] bits respectively. It is recommended that the DIVA is configured with a higher value in order to minimum power consumption. After being divided by dividers A and B, the ERTC\_CLK generates ck\_a and ck\_b clocks, respectively. The ck\_a is used for subsecond update, while the ck\_b is used for calendar update and periodic auto wakeup. The clock frequencies of ck\_a and ck\_b are obtained from the following equation:

$$F_{ck\_a} = \frac{f_{ERTC\_CLK}}{DIVA + 1}$$

$$F_{ck\_b} = \frac{f_{ERTC\_CLK}}{(DIVB + 1) \times (DIVA + 1)}$$

To obtain ck\_b with frequency of 1 Hz, DIVA=127, DIVB=255, and 32.768 kHz LEXT should be used. This ck\_b is then used for calendar update.

*Note: If the divided HEXT is used to clock the ERTC\_CLK, then the HEXT frequency division value must be configured first before switching the clock source to HEXT.*

### 18.3.2 ERTC initialization

#### ERTC register write protection

After a power-on reset, all ERTC registers are write protected. Such protection mechanism is not affected by the system reset. Write access to the ERTC registers (except the ERTC\_STS[14: 8], ERTC\_TAMP and ERTC\_BPRx registers) can be enabled by unlocking write protection.

To unlock the write protection of ERTC registers, follow the steps below:

1. Enable power interface clock by setting PWCEN=1 in the CRM\_APB1EN register
2. Unlock write protection of the battery powered domain by setting BPWEN=1 in PWC\_CTRL register
3. Write 0xCA and 0x53 to the ERTC\_WP register in sequence. Writing an incorrect key will activate the write protection again.

Table 18-1 lists the ERTC registers that can be configured only after the write protection is unlocked and after the initialization mode is entered.

Table 18-1 RTC register map and reset values

| Register  | ERTC_WP enabled   | Whether to enter initialization mode | Others                     |
|-----------|-------------------|--------------------------------------|----------------------------|
| ERTC_TIME | Y                 | Y                                    | -                          |
| ERTC_DATE | Y                 | Y                                    | -                          |
| ERTC_CTRL | Y                 | Bit 7,6, and 4 only                  | -                          |
| ERTC_STS  | Y, except [14: 8] | -                                    | -                          |
| ERTC_DIV  | Y                 | Y                                    | -                          |
| ERTC_WAT  | Y                 | N                                    | Configurable when WATWF=1  |
| ERTC_ALA  | Y                 | N                                    | Configurable when ALAWF =1 |
| ERTC_ALB  | Y                 | N                                    | Configurable when ALBWF =1 |
| ERTC_WP   | -                 | -                                    | -                          |
| ERTC_SBS  | -                 | -                                    | -                          |

|             |   |   |                             |
|-------------|---|---|-----------------------------|
| ERTC_TADJ   | Y | N | Configurable when TADJF=0   |
| ERTC_TSTM   | - | - | -                           |
| ERTC_TSST   | - | - | -                           |
| ERTC_TSSBS  | - | - | -                           |
| ERTC_SCAL   | Y | N | Configurable when CALUPDF=0 |
| ERTC_TAMP   | N | N | -                           |
| ERTC_ALASBS | Y | N | Configurable when ALAWF =1  |
| ERTC_ALBSBS | Y | N | Configurable when ALBWF =1  |
| ERTC_BPRx   | N | N | -                           |

### Clock and calendar initialization

After the register write protection is unlocked, follow the procedure below to initialize clock and calendar:

1. Enter initialization mode by setting IMEN =1.
2. Wait for the initialization flag INITF bit to be set to 1.
3. Configure DIVB and DIVA.
4. Configure the clock and calendar values.
5. Leave the initialization mode by clearing the IMEN bit. Wait until the UPDF bit is set to 1, indicating the completion of the calendar update. The calendar starts counting.

The ERTC also allows the fine-tuning for daylight saving time and clock.

**Daylight saving time feature:** It is used to increase (ADD1H=1) or decrease (DEC1H=1) one hour in the calendar, without completing the whole initialization process.

**Clock calibration:** It is used for the fine calibration of the current clock. If only DECSBS[14: 0] is configured, the value will be added to the DIVB counter and a clock latency will be generated. If only ADD1S=1 is activated, the current clock will increase by one second. If both DECSBS[14: 0] and ADDIS bit are configured, the clock will increase by a fraction of a second.

Time latency (ADD1S=0): DECSBS/(DIVB+1)

Time advance (ADD1S=1): 1-(DECSBS/(DIVB+1))

*Note: To avoid subsecond overflow, SBS[15]=0 must be asserted before setting the ERTC\_TADJ register.*

### Reading the calendar

The ERTC offers two different ways to read the calendar, namely, synchronous read (DREN=0) and asynchronous read (DREN=1).

**DREN=0:** The clock and calendar values can be obtained by reading the synchronous shadow register via the PCLK1. The UPDF bit is set each time the shadow register is synchronized with the ERTC calendar value located in the battery powered domain. The synchronization is performed every two ERTC\_CLK. The shadow register is reset by a system reset. To ensure consistency between the 3 values (ERTC\_SBS, ERTC\_TIME and ERTC\_DATE registers), reading lower-order registers will lock the values in the higher-order registers until the ERTC\_DATE register is read. For example, reading the ERTC\_SBS register will lock the values in the ERTC\_TIME and ERTC\_DATE registers.

**DREN=1**, the ERTC will perform direct read access to the ERTC clock and calendar located in the battery powered domain with the PCLK1, avoiding the occurrence of errors caused by time synchronization. In this mode, the UPDF flag is cleared by hardware. To ensure the data is correct when reading clock and calendar, the software must read the clock and calendar registers twice, and compare the results of two read operations. If the result is not aligned, read again until that the results of two read accesses are consistent. Besides, it is also possible to compare the least significant bits of the two read operations to determine their consistency.

*Note: In Standby and Deepsleep modes, the current calendar values are not copied into the shadow*

registers. When waking up from these two modes, UPDF=0 must be asserted, and then wait until UPDF=1, to ensure that the latest calendar value can be read. In synchronous read (DREN=0) mode, the frequency of the PCLK1 must be at least seven times the ERTC\_CLK frequency. In asynchronous read (DREN=1), an additional APB cycle is required to complete the read operations of the calendar register.

#### Alarm clock initialization

The ERTC contains two programmable alarm clocks: alarm clock A and alarm clock B, and their respective interrupts.

The alarm clock value is programmed with the ERTC\_ALASBS/ERTC\_ALA (ERTC\_ALBSBS/ERTC\_ALB). When the programmed alarm value matches the calendar value, an alarm event is generated if an alarm clock is enabled. The MASKx bit can be used to selectively mask calendar fields. The calendar fields, which are masked, are not allocated with an alarm clock.

Follow the steps below to configure the alarm clocks:

1. Disable alarm clock A or alarm clock B (by setting ALAEN=0 or ALBEN=0);
2. Wait until the ALAWF or ALBWF bit is set to enable write access to the alarm clock A or B;
3. Configure alarm clock A or B registers (ERTC\_ALA/ERTC\_ALASBS and ERTC\_ALB/ERTC\_ALBSBS);
4. Enable alarm clock A or B by setting ALAEN=1 or ALBEN=1.

*Note: If MASK1=0 in the ERTC\_ALA or ERTC\_ALB, the alarm clock can work normally only when the DIVB value is at least equal to 3.*

#### 18.3.3 Periodic automatic wakeup

Periodic automatic wakeup unit is used to wake up ERTC from low power consumption modes automatically. The period is programmed with the VAL[15: 0] bi (When WATCLK[2]=1, it is extended to 17 bits, and the wakeup counter value is VAL+2<sup>16</sup>). When the wakeup counter value drops from the VAL to zero, the WATF bit is set, and a wakeup event is generated, with the wakeup counter being reloaded with the VAL value. An interrupt is also generated if a periodic wakeup interrupt is enabled.

The WATCLK[2: 0] bit can be used to select a wakeup timer clock, including ERTC\_CLK/16, ERTC\_CLK/8, ERTC\_CLK/4, ERTC\_CLK/2 and ck\_b (usually 1Hz). The cooperation between wakeup timer clocks and wakeup counter values enable users to adjust the wakeup period freely.

Follow the steps below to enable a periodic automatic wakeup:

1. Disable a periodic automatic wakeup by setting WATEN=0;
2. Wait until WATWF=1 to enable write access to the wakeup reload timer and WATCLK[2: 0];
3. Configure the wakeup timer counter value and wakeup timer through VAL[15: 0] and WATCLK[2: 0] bits;
4. Enable a timer by setting WATEN=1.

*Note: A wakeup timer is not affected by a system reset and low power consumption modes (Sleep, Deepsleep and Standby modes)*

*Note: In debug mode, if the ERTC\_CLK is selected as wakeup clock, the counter which is used for periodic wakeup works normally.*

#### 18.3.4 ERTC calibration

##### Smooth digital calibration:

Smooth digital calibration has a higher and well-distributed performance than the coarse digital calibration. The calibration is performed by increasing or decreasing ERTC\_CLK in an evenly manner.

The smooth digital calibration period is around 2<sup>20</sup> ERTC\_CLK (32 seconds) when the ERTC\_CLK is 32.768 kHz. The DEC[8: 0] bit specifies the number of pulses to be masked during the 2<sup>20</sup> ERTC\_CLK cycles. A maximum of 511 pulses can be removed. When the ADD bit is set, 512 pulses can be inserted during the 2<sup>20</sup> ERTC\_CLK cycles. When DEC[8: 0] and ADD are sued together, a deviation ranging from -511 to +512 ERTC\_CLK cycles can be added during the 2<sup>20</sup> ERTC\_CLK cycles.

The effective calibrated frequency ( $F_{SCAL}$ ):

$$F_{SCAL} = F_{ERTC\_CLK} \times [1 + \frac{ADD \times 512 - DEC}{2^{20} + DEC - ADD \times 512}]$$

When the divider A is less than 3, the calibration operates as if ADD was equal to 0. The divider B value should be reduced so that each second is accelerated by 8 ERTC\_CLK cycles, which means that 256 ERTC\_CLK cycles are added every 32 seconds. When DEC[8:0] and ADD are sued together, a deviation ranging from -255 to +256 ERTC\_CLK cycles can be added during the  $2^{20}$  ERTC\_CLK cycles.

At this point, the effective calibrated frequency ( $F_{SCAL}$ )

$$F_{SCAL} = F_{ERTC\_CLK} \times [1 + \frac{256 - DEC}{2^{20} + DEC - 256}]$$

It is also possible to select 8 or 16-second digital calibration period through the CAL8 and CAL16 bits. The 8-second period takes priority over 16-second. In other words, when both 8-second and 16-second are enabled, 8-second calibration period prevails.

The CALUPDF flag in the ERTC indicates the calibration status. During the configuration of ERTC\_SCAL registers, the CALUPDF bit is set, indicating that the calibration value is being updated; Once the calibration value is successfully applied, this bit is cleared automatically, indicating the completion of the calibration value update.

### 18.3.5 Reference clock detection

The calendar update can be synchronized (not used in low-power modes) to a reference clock (usually the mains 50 or 60 Hz) with a higher precision. This reference clock is used to calibrate the precision of the calendar update frequency (1 Hz).

When it is enabled, the reference clock edge detection is performed during the first 7 ck\_a periods around each of the calendar updates. When detected, the edge is used to update calendar values, and 3 ck\_a periods are used for subsequent calendar updates. Each time the reference clock edge is detected, the divider A value is forced to reload, making the reference clock and the 1 Hz clock aligned. If the 1 Hz clock has a slight shift, a more accurate reference clock can be used to fine-tune the 1 Hz clock so that it is aligned with the reference clock. If no reference clock edge is detected, the calendar is updated based on ERTC's original clock source.

Note: Once the reference clock detection is enabled, the DIVA and DIVB must be kept at its respective reset value (0x7F and 0xFF respectively).

### 18.3.6 Time stamp function

When time stamp event is detected on the tamper pin (valid edge is detected), the current calendar value will be stored to the time stamp register.

When a time stamp event occurs, the time stamp flag bit (TSF) will be set to 1 in the ERTC\_STS register. If a new time stamp event is detected when time stamp flag (TSF) is already set, then the time stamp overflow flag (TSOF) will be set, but the time stamp registers will remain the result of the last event. By setting the TSIEN bit, an interrupt can be generated when a time stamp event occurs.

#### Usage of time stamp:

1. How to enable time stamp when a valid edge is detected on a tamper pin
  - Select a time stamp in by setting the TSPIN bit
  - Select a rising edge or falling edge to trigger time stamp by setting the TSEDG bit
  - Enable time stamp by setting TSEN=1
2. How to save time stamp on a tamper event
  - Configure tamper detection registers
  - Enable tamper detection time stamp by setting TPTSEN=1

*Note: The TSF bit will be set after two ck\_a cycles following a time stamp event. It is suggested that users poll TSOF bit when the TSF is set.*

### 18.3.7 Tamper detection

The ERTC has two tamper detection modes: TAMP1 and TAMP2. They can be configured as a level detection with filter or edge detection. TAMP1 uses the TSPIN bit to select either ERTC\_MUX1 or ERTC\_MUX2 as a tamper pin, while the TAMP2 can only select ERTC\_MUX2 as a tamper pin.

The TP1F or TP2F will be set to 1 when a valid tamper event is detected. An interrupt will also be generated if a tamper detection interrupt is enabled. If the TPTSEN bit is already set to 1, a time stamp event will be generated accordingly. Once a tamper event occurs, the battery powered registers will be reset so as to ensure data security in the battery powered domain.

#### How to configure edge detection

1. Select edge detection by setting TPFLT=00, and select a valid edge (TP1EDG or TP2EDG)
2. According to your needs, configure whether to activate a time stamp on a tamper event (TPTSEN=1)
3. According to your needs, enable a tamper detection interrupt (TPIEN=1)
4. To use TAMP1 tamper detection mode, either ERTC\_MUX1 or ERTC\_MUX2 (TP1PIN bit) has to be selected as TAMPI mapping, and TAMP1 is enabled (TP1EN=1); to use TAMP2 tamper detection mode, the users only need enable TAMP2 by setting TP2EN=1.

#### How to configure level detection with filtering

1. Select level detection with filtering, and valid level sampling times (TPFLT≠00)
2. Select tamper detection valid level (TP1EDG or TP2EDG)
3. Select tamper detection sampling frequency (TPFREQ\)
4. According to your needs, enable tamper detection pull-up (setting TPPU=1). When TPPU=1 is asserted, tamper detection pre-charge time must be configured through the TPPR bit
5. According to your needs, configure whether to activate a time stamp on a tamper event (TPTSEN=1)
6. According to your needs, enable a tamper interrupt (TPIEN=1)
7. To use TAMP1 tamper detection mode, either ERTC\_MUX1 or ERTC\_MUX2 (TP1PIN bit) has to be selected as TAMPI mapping, and TAMP1 is enabled (TP1EN=1); to use TAMP2 tamper detection mode, the users only need enable TAMP2 by setting TP2EN=1.

In the case of edge detection mode, the following two points deserve our attention:

1. If a rising edge is configured to enable tamper detection, and the tamper detection pin turns to high level before tamper detection is enabled, then a tamper event will be detected right after the tamper detection is enabled;
2. If a falling edge is configured to enable tamper detection, and the tamper detection pin turns to low level before tamper detection is enabled, then a tamper event will be detected right after the tamper detection is enabled;

*Note: Tamper detection is inactive when the battery powered domain is OFF.*

*Note: In Standby mode, precharge feature is not available to TAMP2 (PA0).*

### 18.3.8 Multiplexed function output

ERTC provides a set of multiplexed function output for the following events:

1. Clocks calibrated (OUTSEL=0 and CALOEN=1)
  - Output 512Hz (CALOSEL=0)
  - Output 1Hz (CALOSEL=1)
2. Alarm clock A (OUTSEL=1)
3. Alarm clock B (OUTSEL=2)
4. Wakeup event (OUTSEL=3)

When alarm clock or wakeup event is selected (OUTSEL≠0), it is possible to select output type (open-drain or push-pull) with the OUTTYPE bit, and output polarity with the OUTP bit.

### 18.3.9 ERTC wakeup

ERTC can be woken up by alarm clock, periodic auto wakeup, time stamp or tamper event. To enable an ERTC interrupt, follow the procedure below:

1. Configure the EXINT line corresponding to ERTC interrupts as an interrupt mode and enable it, and select a rising edge
2. Enable a NVIC channel corresponding to ERTC interrupts
3. Enable an ERTC interrupt

Table 18-2 lists the ERTC clock sources, events and interrupts that are able to wakeup low-power modes.

Table 18-2 ERTC low-power mode wakeup

| Clock sources | Events                    | Wake up Sleep | Wake up Deepsleep | Wakeup Standby |
|---------------|---------------------------|---------------|-------------------|----------------|
| HEXT          | Alarm clock A             | ✓             | ✗                 | ✗              |
|               | Alarm clock B             | ✓             | ✗                 | ✗              |
|               | Periodic automatic wakeup | ✓             | ✗                 | ✗              |
|               | Time stamp                | ✓             | ✗                 | ✗              |
|               | Tamper event              | ✓             | ✗                 | ✗              |
| LICK          | Alarm clock A             | ✓             | ✓                 | ✓              |
|               | Alarm clock B             | ✓             | ✓                 | ✓              |
|               | Periodic automatic wakeup | ✓             | ✓                 | ✓              |
|               | Time stamp                | ✓             | ✓                 | ✓              |
|               | Tamper event              | ✓             | ✓                 | ✓              |
| LEXT          | Alarm clock A             | ✓             | ✓                 | ✓              |
|               | Alarm clock B             | ✓             | ✓                 | ✓              |
|               | Periodic automatic wakeup | ✓             | ✓                 | ✓              |
|               | Time stamp                | ✓             | ✓                 | ✓              |
|               | Tamper event              | ✓             | ✓                 | ✓              |

Table 18-3 Interrupt control bits

| Interrupt events          | Event flag | Interrupt enable bit | EXINT line |
|---------------------------|------------|----------------------|------------|
| Alarm clock A             | ALAF       | ALAIEN               | 17         |
| Alarm clock B             | ALBF       | ALBIEN               | 17         |
| Periodic automatic wakeup | WATF       | WATIEN               | 22         |
| Time stamp                | TSF        | TSIEN                | 21         |
| Tamper event              | TP1F/TP2F  | TP1EN                | 21         |

## 18.4 ERTC registers

These peripheral registers must be accessed by words (32 bits).  
ERTC registers are 32-bit addressable registers.

Table 18-4 ERTC register map and reset values

| Register    | Offset    | Reset value |
|-------------|-----------|-------------|
| ERTC_TIME   | 0x00      | 0x0000 0000 |
| ERTC_DATE   | 0x04      | 0x0000 2101 |
| ERTC_CTRL   | 0x08      | 0x0000 0000 |
| ERTC_STS    | 0x0C      | 0x0000 0007 |
| ERTC_DIV    | 0x10      | 0x007F 00FF |
| ERTC_WAT    | 0x14      | 0x0000 FFFF |
| ERTC_ALA    | 0x1C      | 0x0000 0000 |
| ERTC_ALB    | 0x20      | 0x0000 0000 |
| ERTC_WP     | 0x24      | 0x0000 0000 |
| ERTC_SBS    | 0x28      | 0x0000 0000 |
| ERTC_TADJ   | 0x2C      | 0x0000 0000 |
| ERTC_TSTM   | 0x30      | 0x0000 0000 |
| ERTC_TSDT   | 0x34      | 0x0000 000D |
| ERTC_TSSBS  | 0x38      | 0x0000 0000 |
| ERTC_SCAL   | 0x3C      | 0x0000 0000 |
| ERTC_TAMP   | 0x40      | 0x0000 0000 |
| ERTC_ALASBS | 0x44      | 0x0000 0000 |
| ERTC_ALBSBS | 0x48      | 0x0000 0000 |
| ERTC_BPRx   | 0x50-0x9C | 0x0000 0000 |

### 18.4.1 ERTC time register (ERTC\_TIME)

| Bit        | Name     | Reset value | Type | Description                                                                           |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Kept at default value.                                                                |
|            |          |             |      | AM/PM<br>0: AM<br>1: PM                                                               |
| Bit 22     | AMPM     | 0x0         | rw   | Note: This bit is applicable for 12-hr format only. It is 0 for 24-hr format instead. |
| Bit 21: 20 | HT       | 0x0         | rw   | Hour tens                                                                             |
| Bit 19: 16 | HU       | 0x0         | rw   | Hour units                                                                            |
| Bit 15     | Reserved | 0x0         | resd | Kept at its default value.                                                            |
| Bit 14: 12 | MT       | 0x0         | rw   | Minute tens                                                                           |
| Bit 11: 8  | MU       | 0x0         | rw   | Minute units                                                                          |
| Bit 7      | Reserved | 0x0         | resd | Kept at default value.                                                                |
| Bit 6: 4   | ST       | 0x0         | rw   | Second tens                                                                           |
| Bit 3: 0   | SU       | 0x0         | rw   | Second units                                                                          |

### 18.4.2 ERTC date register (ERTC\_DATE)

| Bit        | Name     | Reset value | Type | Description                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at default value.                                                                                                      |
| Bit 23: 20 | YT       | 0x0         | rw   | Year tens                                                                                                                   |
| Bit 19: 16 | YU       | 0x0         | rw   | Year units                                                                                                                  |
|            |          |             |      | Week day<br>0: Forbidden<br>1: Monday<br>2: Tuesday<br>3: Wednesday<br>4: Thursday<br>5: Friday<br>6: Saturday<br>7: Sunday |
| Bit 15: 13 | WK       | 0x1         | rw   |                                                                                                                             |
| Bit 12     | MT       | 0x0         | rw   | Month tens                                                                                                                  |
| Bit 11: 8  | MU       | 0x1         | rw   | Month units                                                                                                                 |
| Bit 7: 6   | Reserved | 0x0         | resd | Kept at default value.                                                                                                      |
| Bit 5: 4   | DT       | 0x0         | rw   | Date tens                                                                                                                   |
| Bit 3: 0   | DU       | 0x1         | rw   | Date units                                                                                                                  |

### 18.4.3 ERTC control register (ERTC\_CTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                          |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at default value.                                                                                                                                                                                                               |
| Bit 23     | CALOEN   | 0x0         | rw   | Calibration output enable<br>0: Calibration output disabled<br>1: Calibration output enabled                                                                                                                                         |
| Bit 22: 21 | OUTSEL   | 0x0         | rw   | Output source selection<br>00: Output source disabled<br>01: Alarm clock A<br>10: Alarm clock B<br>11: Wakeup event                                                                                                                  |
| Bit 20     | OUTP     | 0x0         | rw   | Output polarity<br>0: High<br>1: Low                                                                                                                                                                                                 |
| Bit 19     | CALOSEL  | 0x0         | rw   | Calibration output selection<br>0: 512Hz<br>1: 1Hz                                                                                                                                                                                   |
| Bit 18     | BPR      | 0x0         | rw   | Battery powered domain data register<br>This bit in the battery powered domain is not affected by a system reset. It is used to store the daylight saving time change or others that need to be saved permanently.                   |
| Bit 17     | DEC1H    | 0x0         | wo   | Decrease 1 hour<br>0: No effect<br>1: Subtract 1 hour<br>Note: This bit is applicable only when the current hour is not 0. The next second takes effect when this bit is set (don't set this bit when the hour is being incremented) |
| Bit 16     | ADD1H    | 0x0         | wo   | Add 1 hour<br>0: No effect<br>1: Add 1 hour<br>Note: The next second takes effect when this bit is set (don't set this bit when the hour is being incremented)                                                                       |
| Bit 15     | TSIEN    | 0x0         | rw   | Timestamp interrupt enable<br>0: Timestamp interrupt disabled<br>1: Timestamp interrupt enabled                                                                                                                                      |
| Bit 14     | WATIEN   | 0x0         | rw   | Wakeup timer interrupt enable<br>0: Wakeup timer interrupt disable<br>1: Wakeup timer interrupt enabled                                                                                                                              |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                             |
|----------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 13   | ALBIEN   | 0x0 | rw   | Alarm B interrupt enable<br>0: Alarm B interrupt disabled<br>1: Alarm B interrupt enabled                                                                                                                                                                                                                                                                   |
| Bit 12   | ALAIEN   | 0x0 | rw   | Alarm A interrupt enable<br>0: Alarm A interrupt disabled<br>1: Alarm A interrupt enabled                                                                                                                                                                                                                                                                   |
| Bit 11   | TSEN     | 0x0 | rw   | Timestamp enable<br>0: Timestamp disabled<br>1: Timestamp enabled                                                                                                                                                                                                                                                                                           |
| Bit 10   | WATEN    | 0x0 | rw   | Wakeup timer enable<br>0: Wakeup timer disabled<br>1: Wakeup timer enabled                                                                                                                                                                                                                                                                                  |
| Bit 9    | ALBEN    | 0x0 | rw   | Alarm B enable<br>0: Alarm B disabled<br>1: Alarm B enabled                                                                                                                                                                                                                                                                                                 |
| Bit 8    | ALAEN    | 0x0 | rw   | Alarm A enable<br>0: Alarm A disabled<br>1: Alarm A enabled                                                                                                                                                                                                                                                                                                 |
| Bit 7    | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                      |
| Bit 6    | HM       | 0x0 | rw   | Hour mode<br>0: 24-hour format<br>1: 12-hour format                                                                                                                                                                                                                                                                                                         |
| Bit 5    | DREN     | 0x0 | rw   | Date/time register direct read enable<br>0: Date/time register direct read disabled. ERTC_TIME, ERTC_DATE and ERTC_SBS values are taken from the synchronized registers, which are updated once every two ERTC_CLK cycles<br>1: Date/time register direct read enabled. ERTC_TIME, ERTC_DATE and ERTC_SBS values are taken from the battery powered domain. |
| Bit 4    | RCDEN    | 0x0 | rw   | Reference clock detection enable<br>0: Reference clock detection disabled<br>1: Reference clock detection enabled                                                                                                                                                                                                                                           |
| Bit 3    | TSEDG    | 0x0 | rw   | Timestamp trigger edge<br>0: Rising edge<br>1: Falling edge                                                                                                                                                                                                                                                                                                 |
| Bit 2: 0 | WATCLK   | 0x0 | rw   | Wakeup timer clock selection<br>000: ERTC_CLK/16<br>001: ERTC_CLK/8<br>010: ERTC_CLK/4<br>011: ERTC_CLK/2<br>10x: ck_a<br>11x: ck_a is selected. $2^{16}$ is added to the wakeup counter value, and wakeup time = ERTC_WAT+ $2^{16}$ .<br><i>Note: The write access to this field is supported when WATEN=0 and WATWF=1.</i>                                |

#### 18.4.4 ERTC initialization and status register (ERTC\_STS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                     |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                          |
| Bit 16     | CALUPDF  | 0x0         | ro   | Calibration value update complete flag<br>0: Calibration value update is complete<br>1: Calibration value update is in progress |
| Bit 15     | Reserved | 0x0         | resd | Kept at default value.                                                                                                          |
| Bit 14     | TP2F     | 0x0         | rw0c | Tamper detection 2 flag<br>0: No tamper event<br>1: Tamper event occurred                                                       |
| Bit 13     | TP1F     | 0x0         | rw0c | Tamper detection 1 flag                                                                                                         |

|        |       |     |      |                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |       |     |      | 0: No tamper event<br>1: Tamper event occurred                                                                                                                                                                                                                                                                                                    |
| Bit 12 | TSOF  | 0x0 | rw0c | Timestamp overflow flag<br>0: No timestamp overflow<br>1: Timestamp overflow occurs<br><i>If a new time stamp event is detected when time stamp flag (TSF) is already set, this bit will be set by hardware.</i>                                                                                                                                  |
| Bit 11 | TSF   | 0x0 | rw0c | Timestamp flag<br>0: No timestamp event<br>1: Timestamp event occurs<br><i>It is recommended to double check the TSOF flag after reading a timestamp and clearing the TSF. Otherwise, a new timestamp event may be detected while clearing the TSF.</i><br><i>Note: The clearing operation of this bit takes effect after two APB_CLK cycles.</i> |
| Bit 10 | WATF  | 0x0 | rw0c | Wakeup timer flag<br>0: No wakeup timer event<br>1: Wakeup timer event occurs<br><i>Note: The clearing operation of this bit takes effect after two APB_CLK cycles.</i>                                                                                                                                                                           |
| Bit 9  | ALBF  | 0x0 | rw0c | Alarm clock B flag<br>0: No alarm clock event<br>1: Alarm clock event occurred<br><i>Note: The clearing operation of this bit takes effect after two APB_CLK cycles.</i>                                                                                                                                                                          |
| Bit 8  | ALAF  | 0x0 | rw0c | Alarm clock A flag<br>0: No alarm clock event<br>1: Alarm clock event occurred<br><i>Note: The clearing operation of this bit takes effect after two APB_CLK cycles.</i>                                                                                                                                                                          |
| Bit 7  | IMEN  | 0x0 | rw   | Initialization mode enable<br>0: Initialization mode disabled<br>1: Initialization mode enabled<br><i>When an initialization mode is entered, the calendar stops running.</i>                                                                                                                                                                     |
| Bit 6  | IMF   | 0x0 | ro   | Enter initialization mode flag<br>0: Initialization mode is not entered<br>1: Initialization mode is entered<br><i>The ERTC_TIME, ERTC_DATE and ERTC_DIV registers can be modified only when an initialization mode is enabled (INITEN=1) and entered (INITEF=1).</i>                                                                             |
| Bit 5  | UPDF  | 0x0 | rw0c | Calendar update flag<br>0: Calendar update is in progress<br>1: Calendar update is complete<br><i>The UPDF bit is set each time ERTC_TIME, ERTC_DATE and ERTC_SBS are synchronized with the ERTC calendar value located in the battery powered domain. The synchronization is performed every two ERTC_CLK cycles.</i>                            |
| Bit 4  | INITF | 0x0 | ro   | Calendar initialization flag<br>0: Calendar has not been initialized<br>1: Calendar has been initialized<br><i>This bit is set when the calendar year filed (ERTC_DATE) is different from 0. It is cleared when the year is 0.</i>                                                                                                                |
| Bit 3  | TADJF | 0x0 | ro   | Time adjustment flag<br>0: No time adjustment<br>1: Time adjustment is in progress<br><i>This bit is automatically set when a write access to the ERTC_TADJ register is performed. It is automatically cleared at the end of time adjustment.</i>                                                                                                 |
| Bit 2  | WATWF | 0x1 | ro   | Wakeup timer register allows write flag<br>0: Wakeup timer register configuration not allowed<br>1: Wakeup timer register configuration allowed                                                                                                                                                                                                   |
| Bit 1  | ALBWF | 0x1 | ro   | Alarm b register allows write flag<br>0: Alarm B register write operation not allowed                                                                                                                                                                                                                                                             |

|       |       |     |    |                                                                                                                                      |
|-------|-------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | 1: Alarm B register write operation allowed                                                                                          |
| Bit 0 | ALAWF | 0x1 | ro | Alarm A register allows write flag<br>0: Alarm A register write operation not allowed<br>1: Alarm A register write operation allowed |
|       |       |     |    |                                                                                                                                      |

#### 18.4.5 ERTC divider register (ERTC\_DIV)

| Bit        | Name     | Reset value | Type | Description                                                |
|------------|----------|-------------|------|------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Kept at default value.                                     |
| Bit 22: 16 | DIVA     | 0x7F        | rw   | Divider A                                                  |
| Bit 15     | Reserved | 0x0         | resd | Kept at default value.                                     |
| Bit 14: 0  | DIVB     | 0x00FF      | rw   | Divider B<br>Calendar clock = ERTC_CLK/((DIVA+1)x(DIVB+1)) |

#### 18.4.6 ERTC wakeup timer register (ERTC\_WAT)

| Bit        | Name     | Reset value | Type | Description               |
|------------|----------|-------------|------|---------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.    |
| Bit 15: 0  | VAL      | 0xFFFF      | rw   | Wakeup timer reload value |

#### 18.4.7 ERTC alarm clock A register (ERTC\_ALA)

| Bit        | Name  | Reset value | Type | Description                                                                                                         |
|------------|-------|-------------|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 31     | MASK4 | 0x0         | rw   | Date/week day mask<br>0: Date/week day is not masked<br>1: Alarm clock doesn't care about date/week day             |
| Bit 30     | WKSEL | 0x0         | rw   | Date/week day select<br>0: Date<br>1: Week day (DT[1: 0] is not used)                                               |
| Bit 29: 28 | DT    | 0x0         | rw   | Date tens                                                                                                           |
| Bit 27: 24 | DU    | 0x0         | rw   | Date/week day units                                                                                                 |
| Bit 23     | MASK3 | 0x0         | rw   | Hour mask<br>0: No hour mask<br>1: Alarm clock doesn't care about hours                                             |
| Bit 22     | AMPM  | 0x0         | rw   | AM/PM<br>0: AM<br>1: PM<br><i>Note: This bit is applicable for 12-hour format only. It is 0 for 24-hour format.</i> |
| Bit 21: 20 | HT    | 0x0         | rw   | Hour tens                                                                                                           |
| Bit 19: 16 | HU    | 0x0         | rw   | Hour units                                                                                                          |
| Bit 15     | MASK2 | 0x0         | rw   | Minute mask<br>0: No minute mask<br>1: Alarm clock doesn't care about minutes                                       |
| Bit 14: 12 | MT    | 0x0         | rw   | Minute tens                                                                                                         |
| Bit 11: 8  | MU    | 0x0         | rw   | Minute units                                                                                                        |
| Bit 7      | MASK1 | 0x0         | rw   | Second mask<br>0: No second mask<br>1: Alarm clock doesn't care about seconds                                       |
| Bit 6: 4   | ST    | 0x0         | rw   | Second tens                                                                                                         |
| Bit 3: 0   | SU    | 0x0         | rw   | Second units                                                                                                        |

#### 18.4.8 ERTC alarm clock B register (ERTC\_ALB)

| Bit        | Name  | Reset value | Type | Description                                                                                             |
|------------|-------|-------------|------|---------------------------------------------------------------------------------------------------------|
| Bit 31     | MASK4 | 0x0         | rw   | Date/week day mask<br>0: Date/week day is not masked<br>1: Alarm clock doesn't care about date/week day |
| Bit 30     | WKSEL | 0x0         | rw   | Date/week day select<br>0: Date<br>1: Week day (DT[1: 0] is not used)                                   |
| Bit 29: 28 | DT    | 0x0         | rw   | Date tens                                                                                               |
| Bit 27: 24 | DU    | 0x0         | rw   | Date/week day units                                                                                     |

|            |       |     |    |                                                                                                                     |
|------------|-------|-----|----|---------------------------------------------------------------------------------------------------------------------|
| Bit 23     | MASK3 | 0x0 | rw | Hour mask<br>0: No hour mask<br>1: Alarm clock doesn't care about hours                                             |
| Bit 22     | AMPM  | 0x0 | rw | AM/PM<br>0: AM<br>1: PM<br><i>Note: This bit is applicable for 12-hour format only. It is 0 for 24-hour format.</i> |
| Bit 21: 20 | HT    | 0x0 | rw | Hour tens                                                                                                           |
| Bit 19: 16 | HU    | 0x0 | rw | Hour units                                                                                                          |
| Bit 15     | MASK2 | 0x0 | rw | Minute mask<br>0: No minute mask<br>1: Alarm clock doesn't care about minutes                                       |
| Bit 14: 12 | MT    | 0x0 | rw | Minute tens                                                                                                         |
| Bit 11: 8  | MU    | 0x0 | rw | Minute units                                                                                                        |
| Bit 7      | MASK1 | 0x0 | rw | Second mask<br>0: No second mask<br>1: Alarm clock doesn't care about seconds                                       |
| Bit 6: 4   | ST    | 0x0 | rw | Second tens                                                                                                         |
| Bit 3: 0   | SU    | 0x0 | rw | Second units                                                                                                        |

#### 18.4.9 ERTC write protection register (ERTC\_WP)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                 |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x000000    | resd | Kept at default value                                                                                                                                       |
| Bit 7: 0  | CMD      | 0x00        | wo   | Command register<br>All ERTC register write protection is unlocked by writing 0xCA and then 0x53. Writing any other value will reactivate write protection. |

#### 18.4.10 ERTC subsecond register (ERTC\_SBS)

| Bit        | Name     | Reset value | Type | Description                                                                                         |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value                                                                               |
| Bit 15: 0  | SBS      | 0x0000      | ro   | Sub-second value<br>Subsecond is the value in the DIVB counter. Clock frequency = ERTC_CLK/(DIVA+1) |

#### 18.4.11 ERTC time adjustment register (ERTC\_TADJ)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                           |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | ADD1S    | 0x0         | wo   | Add 1 second<br>0: No effect<br>1: Add one second<br>This bit can be written only when TADJF=0. It is intended to be used with DECSBS in order to fine-tune the time. |
| Bit 30: 15 | Reserved | 0x0000      | resd | Kept at default value                                                                                                                                                 |
| Bit 14: 0  | DECSBS   | 0x0000      | wo   | DECSBS[14: 0]: Decrease sub-second value<br>Delay (ADD1S=0): Delay = DECSBS/(DIVB+1)<br>Advance (ADD1S=1): Advance =1-(DECSBS/(DIVB+1))                               |

#### 18.4.12 ERTC time stamp time register (ERTC\_TSTM)

| Bit        | Name     | Reset value | Type | Description                                                                                                         |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Kept at default value                                                                                               |
| Bit 22     | AMPM     | 0x0         | ro   | AM/PM<br>0: AM<br>1: PM<br><i>Note: This bit is applicable for 12-hour format only. It is 0 for 24-hour format.</i> |
| Bit 21: 20 | HT       | 0x0         | ro   | Hour tens                                                                                                           |
| Bit 19: 16 | HU       | 0x0         | ro   | Hour units                                                                                                          |

|            |          |     |      |                           |
|------------|----------|-----|------|---------------------------|
| Bit 15     | Reserved | 0x0 | resd | Kept at default value     |
| Bit 14: 12 | MT       | 0x0 | ro   | Minute tens               |
| Bit 11: 8  | MU       | 0x0 | ro   | Minute units              |
| Bit 7      | Reserved | 0x0 | resd | Kept at its default value |
| Bit 6: 4   | ST       | 0x0 | ro   | Second tens               |
| Bit 3: 0   | SU       | 0x0 | ro   | Second units              |

*Note: The content of this register is valid only when the TSF is set in the ERTC\_STS register. It is cleared when TSF bit is reset.*

#### 18.4.13 ERTC time stamp date register (ERTC\_TS DT)

| Bit        | Name     | Reset value | Type | Description           |
|------------|----------|-------------|------|-----------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value |
| Bit 15: 13 | WK       | 0x0         | ro   | Week day              |
| Bit 12     | MT       | 0x0         | ro   | Month tens            |
| Bit 11: 8  | MU       | 0x0         | ro   | Month units           |
| Bit 7: 6   | Reserved | 0x0         | resd | Kept at default value |
| Bit 5: 4   | DT       | 0x0         | ro   | Date tens             |
| Bit 3: 0   | DU       | 0x0         | ro   | Date units            |

*Note: The content of this register is valid only when the TSF is set in the ERTC\_STS register. It is cleared when TSF bit is reset.*

#### 18.4.14 ERTC time stamp subsecond register (ERTC\_TSSBS)

| Bit        | Name     | Reset value | Type | Description           |
|------------|----------|-------------|------|-----------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value |
| Bit 15: 0  | SBS      | 0x0000      | ro   | Sub-second value      |

*Note: The content of this register is valid only when the TSF is set in the ERTC\_STS register. It is cleared when TSF bit is reset.*

#### 18.4.15 ERTC smooth calibration register (ERTC\_SCAL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value                                                                                                                                                                                                                                               |
| Bit 15     | ADD      | 0x0         | rw   | Add ERTC clock<br>0: No ERTC clock added<br>1: One ERTC_CLK is inserted every $2^{11}$ ERTC_CLK cycles                                                                                                                                                              |
| Bit 14     | CAL8     | 0x0         | rw   | 8-second calibration period<br>0: No effect<br>1: 8-second calibration                                                                                                                                                                                              |
| Bit 13     | CAL16    | 0x0         | rw   | 16 second calibration period<br>0: No effect<br>1: 16-second calibration                                                                                                                                                                                            |
| Bit 12: 9  | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                                                                               |
| Bit 8: 0   | DEC      | 0x000       | rw   | Decrease ERTC clock<br>DEC out of ERTC_CLK cycles are masked during the $2^{20}$ ERTC_CLK cycles. This bit is usually used with ADD.<br>When the ADD is set, the actual number of ERTC_CLK is equal to $2^{20}+512\text{-DEC}$ during the $2^{20}$ ERTC_CLK cycles. |

### 18.4.16 ERTC tamper configuration register (ERTC\_TAMP)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 19 | Reserved | 0x0000      | resd | Kept at default value                                                                                                                                                       |
|            |          |             |      | Output type                                                                                                                                                                 |
| Bit 18     | OUTTYPE  | 0x0         | rw   | 0: Open-drain output<br>1: Push-pull output                                                                                                                                 |
|            |          |             |      | Time stamp detection pin selection                                                                                                                                          |
| Bit 17     | TSPIN    | 0x0         | rw   | 0: ERTC_MUX1<br>1: ERTC_MUX2                                                                                                                                                |
|            |          |             |      | Tamper detection pin selection                                                                                                                                              |
| Bit 16     | TP1PIN   | 0x0         | rw   | 0: ERTC_MUX1<br>1: ERTC_MUX2                                                                                                                                                |
|            |          |             |      | Tamper detection pull-up                                                                                                                                                    |
| Bit 15     | TPPU     | 0x0         | rw   | 0: Tamper detection pull-up enabled<br>1: Tamper detection pull-up disabled                                                                                                 |
|            |          |             |      | Tamper detection pre-charge time                                                                                                                                            |
| Bit 14: 13 | TPPR     | 0x0         | rw   | 0: 1 ERTC_CLK cycle<br>1: 2 ERTC_CLK cycles<br>2: 4 ERTC_CLK cycles<br>3: 8 ERTC_CLK cycles                                                                                 |
|            |          |             |      | Tamper detection filter time                                                                                                                                                |
| Bit 12: 11 | TPFLT    | 0x0         | rw   | 0: No filter<br>1: Tamper is detected after 2 consecutive samples<br>2: Tamper is detected after 4 consecutive samples<br>3: Tamper is detected after 8 consecutive samples |
|            |          |             |      | Tamper detection frequency                                                                                                                                                  |
| Bit 10: 8  | TPFREQ   | 0x0         | rw   | 0: ERTC_CLK/32768<br>1: ERTC_CLK/16384<br>2: ERTC_CLK/8192<br>3: ERTC_CLK/4096<br>4: ERTC_CLK/2048<br>5: ERTC_CLK/1024<br>6: ERTC_CLK/512<br>7: ERTC_CLK/256                |
|            |          |             |      | Tamper detection timestamp enable                                                                                                                                           |
| Bit 7      | TPTSEN   | 0x0         | rw   | 0: Tamper detection timestamp disabled<br>1: Tamper detection timestamp enabled. Save timestamp on a tamper event.                                                          |
| Bit 6: 5   | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                       |
|            |          |             |      | Tamper detection 2 valid edge                                                                                                                                               |
| Bit 4      | TP2EDG   | 0x0         |      | No filtering (TPFLT=0):<br>0: Rising edge<br>1: Falling edge                                                                                                                |
|            |          |             |      | Filtering (TPFLT>0):<br>0: Low level<br>1: High level                                                                                                                       |
|            |          |             |      | Tamper detection 2 enable                                                                                                                                                   |
| Bit 3      | TP2EN    | 0x0         | rw   | 0: Tamper detection 2 disabled<br>1: Tamper detection 2 enabled                                                                                                             |
|            |          |             |      | Tamper detection interrupt enable                                                                                                                                           |
| Bit 2      | TPIEN    | 0x0         | rw   | 0: Tamper detection interrupt disabled<br>1: Tamper detection interrupt enabled                                                                                             |

|       |        |     |    |                                                                                                                       |
|-------|--------|-----|----|-----------------------------------------------------------------------------------------------------------------------|
|       |        |     |    | Tamper detection 1 valid edge<br>If TPFLT=0:<br>0: Rising edge<br>1: Falling edge<br>If TPFLT>0:<br>0: Low<br>1: High |
| Bit 1 | TP1EDG | 0x0 | rw | Tamper detection 1 enable<br>0: Tamper detection 1 disabled<br>1: Tamper detection 1 enabled                          |

#### 18.4.17 ERTC alarm clock A subsecond register (ERTC\_ALASBS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 28 | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                                               |
|            |          |             |      | Sub-second mask<br>0: No comparison. Alarm A doesn't care about subseconds.<br>1: SBS[0] is compared<br>2: SBS[1: 0] are compared<br>3: SBS[2: 0] are compared<br>...<br>14: SBS[13: 0] are compared<br>15: SBS[14: 0] are compared |
| Bit 27: 24 | SBSMSK   | 0x0         | rw   |                                                                                                                                                                                                                                     |
| Bit 23: 15 | Reserved | 0x000       | rw   | Kept at default value                                                                                                                                                                                                               |
| Bit 14: 0  | SBS      | 0x0000      | rw   | Sub-second value                                                                                                                                                                                                                    |

#### 18.4.18 ERTC alarm clock B subsecond register (ERTC\_ALBSBS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 28 | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                                               |
|            |          |             |      | Sub-second mask<br>0: No comparison. Alarm A doesn't care about subseconds.<br>1: SBS[0] is compared<br>2: SBS[1: 0] are compared<br>3: SBS[2: 0] are compared<br>...<br>14: SBS[13: 0] are compared<br>15: SBS[14: 0] are compared |
| Bit 27: 24 | SBSMSK   | 0x0         | rw   |                                                                                                                                                                                                                                     |
| Bit 23: 15 | Reserved | 0x000       | rw   | Kept at its default value                                                                                                                                                                                                           |
| Bit 14: 0  | SBS      | 0x0000      | rw   | Sub-second value                                                                                                                                                                                                                    |

#### 18.4.19 ERTC battery powered domain data register (ERTC\_BPRx)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                   |
|-----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | DT   | 0x0000 0000 | rw   | Battery powered domain data<br>BPR_DTx registers are powered on by V <sub>BAT</sub> so that they are not reset by a system reset. They are reset on a tamper event or when a battery powered domain is reset. |

# 19 Analog-to-digital converter (ADC)

## 19.1 ADC introduction

The ADC is a peripheral that converts an analog input signal into a 12-bit digital signal. Its sampling rate is as high as 2 MSPS. It has up to 18 channels (internal + external) for sampling and conversion. The ADC has a total of 16 external input channel sources.

## 19.2 ADC main features

In terms of analog:

- 12-bit configurable resolution
- Self-calibration time: 205 ADC clock cycles
- ADC conversion time: ADC conversion time is 0.5  $\mu$ s at max. 28 MHz
- ADC supply requirement: refer to Datasheet
- ADC input range:  $V_{REF-} \leq V_{IN} \leq V_{REF+}$

In terms of digital control:

- Regular channels and preempted channels with different priority
- Regular channels and preempted channels both have their own trigger detection circuit
- Each channel can independently define its own sampling time
- Conversion sequence supports various conversion modes
- Hardware oversampling up to equivalent 16-bit resolution
- Optional data alignment mode
- Programmable voltage monitoring threshold
- Regular channels with DMA transfers
- Interrupt generation at one of the following events:
  - End of the conversion of preempted channels
  - End of the conversion of regular channels
  - Voltage outside the threshold programmed

## 19.3 ADC structure

Figure 19-1 shows the block diagram of ADC.

Figure 19-1 ADC block diagram



### Input pin description:

- $V_{DDA}$ : Analog supply, ADC analog supply
- $V_{SSA}$ : Analog supply ground, ADC analog supply ground
- ADCx\_IN: Analog input signal channel

Refer to the Datasheet for more information about the input pin connections and voltage ranges.

## 19.4 ADC functional overview

### 19.4.1 Channel management

#### Analog signal channel input:

There are 18 analog signal channel inputs for each of the ADCs, expressed by ADC\_INx (x=0 to 17).

- ADC\_IN0 to ADC\_IN15 are external analog inputs, ADC\_IN16 represents internal temperature sensor, ADC\_IN17 represents internal reference voltage.

#### Channel conversion

The conversions are divided into two groups: ordinary and preempted channels. The preempted group has priority over the ordinary group.

If the preempted channel trigger occurs during the ordinary channel conversion, then the ordinary channel conversion is interrupted, giving priority to the preempted channel, and the ordinary channel continues its conversion at the end of the preempted channel conversion. If the ordinary channel trigger occurs during the preempted channel conversion, the ordinary channel conversion won't start until the end of the preempted channel conversion.

Program the ADC\_Inx into the ordinary channel sequence (ADC\_OSQx) and the preempted channel sequence (ADC\_PSQ), and the same channel can be repeated, the total number of sequences is determined by OCLEN and PCLEN, then it is ready to enable the ordinary channel or preempted channel conversion.

#### 19.4.1.1 Internal temperature sensor

The temperature sensor is connected to ADC\_IN16. Before the temperature sensor channel conversion, the ITSRVEN bit in the ADC\_CTRL2 register must be enabled and wait after power-on time.

The temperature sensor output voltage changes linearly with temperature. The offset of this linear function depends on each chip due to process variations from one chip to another. The internal temperature sensor is more suited for applications that detect temperature variations instead of absolute temperatures. Using the ADC to convert ADC\_IN16, the current temperature sensor output voltage can be read. Then the following formula can be used to calculate the current temperature.

Obtain the temperature using the following formula:

$$\text{Temperature (in } ^\circ\text{C)} = \{(V_{25} - V_{SENSE}) / \text{Avg\_Slope}\} + 25.$$

Where,

$V_{25}$  =  $V_{SENSE}$  value for  $25^\circ$  C and

Avg\_Slope = Average Slope for curve between Temperature vs.  $V_{SENSE}$  (given in mV/ $^\circ$  C). Refer to the data sheet's electrical characteristics section for the actual average slope.

#### 19.4.1.2 Internal reference voltage

The internal reference voltage of the typical value 1.2 V is connected to ADC\_IN17. It is required to enable the ITSRVEN bit in the ADC\_CTRL2 register before converting the internal reference channel. The converted data of such channel can be used to calculate the external reference voltage.

### 19.4.2 ADC operation process

*Figure 19-2* shows the basic operation process of the ADC. It is recommended to do the calibration after the initial power-on in order to improve the accuracy of sampling and conversion. After the calibration, trigger is used to enable ADC sampling and conversion. Read data at the end of the conversion.

Figure 19-2 ADC basic operation process



#### 19.4.2.1 Power-on and calibration

##### Power-on

Set the ADC1EN bit in the CRM\_APB2EN register to enable ADC clocks: PCLK2 and ADCCLK.

Program the desired ADCCLK frequency by setting the ADCDIV bit in the ADC\_CCTRL register. ADCCLK is provided by a divided HICK.

*Note: ADCCLK must be less than 28 MHz, while the ADCCLK frequency must be lower than PCLK2.*

Then set the ADCEN bit in the ADC\_CTRL2 register to enable the ADC, and wait until the t<sub>STAB</sub> flag is set before starting ADC conversion. Clear the ADCEN bit will stop ADC conversion, resulting in a reset, and disabling ADC to save power.

##### Calibration

After power-on, the ADC calibration is enabled by setting the ADCAL bit in the ADC\_CTRL2 register. When the calibration is complete, the ADCAL bit is cleared by hardware and the conversion is triggered by software.

After each calibration, the calibration value is stored in the lower 7 bits of the ADC\_ODT register, and then it is automatically sent back to the ADC so as to eliminate capacitance errors. The storage of the calibration value will not set the CCE flag, or generate an interrupt or DMA request.

Figure 19-3 ADC power-on and calibration



#### 19.4.2.2 Trigger

The ADC trigger contains ordinary channel trigger and preempted channel trigger. The ordinary channel conversion is triggered by ordinary channels, while the preempted channel conversion is triggered by preempted ones. Only by enabling the OCTEN or PCTEN bit in the ADC\_CTRL2 register can the ADC start conversion by detecting the rising edge of trigger source.

The conversion can be triggered by software write operation to the OCSWTRG and PCSWTRG bits in the ADC\_CTRL2 register, or by an external event. The external events include timer trigger and pin trigger, depending on the OCTESEL and PCTESEL bits in the ADC\_CTRL2 register, as shown in Table 19-1.

Table 19-1 Trigger sources for ordinary channels

| OCTESEL | Trigger source            | PCTESEL | Trigger source            |
|---------|---------------------------|---------|---------------------------|
| 000     | TMR1_TRGOUT event         | 000     | TMR1_CH2 event            |
| 001     | TMR1_CH4 event            | 001     | TMR1_CH3 event            |
| 010     | TMR2_TRGOUT event         | 010     | TMR2_CH4 event            |
| 011     | TMR3_TRGOUT event         | 011     | TMR3_CH4 event            |
| 100     | TMR9_TRGOUT event         | 100     | TMR9_CH1 event            |
| 101     | TMR1_CH1 event            | 101     | TMR6_TRGOUT event         |
| 110     | EXINT line11 external pin | 110     | EXINT line15 external pin |
| 111     | OCSWTRG bit               | 111     | PCSWTRG bit               |

#### 19.4.2.3 Sampling and conversion sequence

The sampling period can be configured by setting the CSPTx bit in the ADC\_SPT1 and ADC\_SPT2 registers. The duration required for a single conversion is calculated based on the following formula:

$$\text{A single conversion time (ADCCLK period)} = \text{sampling time} + 12.5$$

Example:

If the CSPTx selects 1.5 cycles, then a single conversion needs  $1.5 + 12.5 = 14$  ADCCLK cycles.

### 19.4.3 Conversion sequence management

Only one channel is converted at each trigger, by default, that is, OSN1-defined channel or PSN4-defined channel.

The following section describes various conversion sequence modes in detail. This mode enables multiple channels to be converted in a specific sequence.

#### 19.4.3.1 Sequence mode

The sequence mode is enabled by setting the SQEN bit in the ADC\_CTRL1 register. The ADC\_OSQx register is used to configure the sequence and the number of ordinary channels, while the ADC\_PSQ register is used to define the sequence and the number of preempted channels. After the sequence mode is enabled, a single trigger event enables the conversion of a group of channels in order. The ordinary channels start converting from the QSN1 while the preempted channels starts from the PSNx, where  $x=4-PCLEN$ . Figure 18-4 shows an example of the behavior in sequence mode.

Figure 19-4 Sequence mode



#### 19.4.3.2 Preempted group automatic conversion mode

The automatic conversion mode for preempted group is enabled by setting the PCAUTOEN bit in the ADC\_CTRL1 register. In this mode, once the ordinary channel conversion is over, the preempted group will automatically starts its conversion. This mode can work in conjunction with the sequence mode. In this way, the preempted group conversion starts automatically at the end of the conversion of the ordinary group. [Figure 19-5](#) shows an example of the behavior when the automatic preempted group conversion mode works with the ordinary group.

Figure 19-5 Preempted group auto conversion mode



### 19.4.3.3 Repetition mode

The repetition mode is enabled by setting the RPEN bit in the ADC\_CTRL2 register. When a trigger signal is detected, the ordinary channels will be converted repeatedly. This mode can work in conjunction with the ordinary channel conversion in sequence mode to enable the repeated conversion of the ordinary group. Such mode can also work with the preempted group auto conversion mode to repeatedly convert the ordinary group and preempted group in sequence. Figure 19-6 shows an example of the behavior when the repetition mode works with the sequence mode and preempted group auto conversion mode.

Figure 19-6 Repetition mode



### 19.4.3.4 Partition mode

The partition mode of the ordinary group can be enabled by setting the OCPEN bit in the ADC\_CTRL1 register. In this mode, the ordinary group conversion sequence length (OCLEN bit in the ADC\_OSQ1 register) is divided into subgroups. The number of channels in a subgroup is defined through the OCPCNT bit in the ADC\_CTRL1 register. When a trigger occurs, all channels in the subgroup will be converted. Each trigger selects a different subgroup in order.

Setting the PCPEN bit in the ADC\_CTRL1 register enables the partition mode of preempted group. In this mode, the preempted group conversion sequence length (OCLEN bit in the ADC\_OSQ1 register) is divided into subgroups, each of which has only one channel. When a trigger occurs, the channel in the subgroup will be converted. Each trigger event selects a different sub-group in order.

The partition mode and repetition mode cannot be used simultaneously. [Figure 19-7](#) shows an example of the behavior in partition mode for ordinary group and preempted group.

Figure 19-7 Partition mode



## 19.4.4 Oversampling

The converted data of a single oversampling are obtained by enabling multiple conversions of the same channel and then averaging the cumulative converted data.

- Oversampling ratio is selected through the OSRSEL bit in the ADC\_OVSP register. This bit is used to specify the oversampling multiple, which is done by converting the same channel many times
- Oversampling shift is selected through the OSSSEL bit in the ADC\_OVSP register. This bit defines the average coefficient, which is done by right shift.

If the averaged data is greater than 16 bits, then only the right-aligned 16-bit data are fetched and put into a 16-bit data register, shown in Table 19-2.

Example:

If 4x oversampling is selected through the OSRSEL bit, then the same channel is converted by four times in a single oversampling conversion, and the converted data derived from 4 conversions is put together. If 6-bit resolution is selected through the OSSSE bit, then the cumulative data is divided by  $2^6$  and rounded up.

Table 19-2 Correlation between maximum cumulative data, oversampling multiple and shift digits

| Oversampling multiple | 2x     | 4x     | 8x     | 16x     | 32x     | 64x     | 128x    | 256x     |
|-----------------------|--------|--------|--------|---------|---------|---------|---------|----------|
| Max cumulative data   | 0x1FFE | 0x3FFC | 0x7FF8 | 0xFFFF0 | 0x1FFE0 | 0x3FFC0 | 0x7FF80 | 0xFFFF00 |
| No shift              | 0x1FFE | 0x3FFC | 0x7FF8 | 0xFFFF0 | 0x1FFE0 | 0x3FFC0 | 0x7FF80 | 0xFFFF00 |
| Shift 1 bit           | 0x0FFF | 0x1FFE | 0x3FFC | 0x7FF8  | 0xFFFF0 | 0x1FFE0 | 0x3FFC0 | 0x7FF80  |
| Shift 2 bit           | 0x0800 | 0x0FFF | 0x1FFE | 0x3FFC  | 0x7FF8  | 0xFFFF0 | 0x1FFE0 | 0x3FFC0  |
| Shift 3 bit           | 0x0400 | 0x0800 | 0x0FFF | 0x1FFE  | 0x3FFC  | 0x7FF8  | 0xFFFF0 | 0x1FFE0  |
| Shift 4 bit           | 0x0200 | 0x0400 | 0x0800 | 0x0FFF  | 0x1FFE  | 0x3FFC  | 0x7FF8  | 0xFFFF0  |
| Shift 5 bit           | 0x0100 | 0x0200 | 0x0400 | 0x0800  | 0x0FFF  | 0x1FFE  | 0x3FFC  | 0x7FF8   |
| Shift 6 bit           | 0x0080 | 0x0100 | 0x0200 | 0x0400  | 0x0800  | 0x0FFF  | 0x1FFE  | 0x3FFC   |
| Shift 7 bit           | 0x0040 | 0x0080 | 0x0100 | 0x0200  | 0x0400  | 0x0800  | 0x0FFF  | 0x1FFE   |
| Shift 8 bit           | 0x020  | 0x0040 | 0x0080 | 0x0100  | 0x0200  | 0x0400  | 0x0800  | 0x0FFF   |

When using oversampling conversion mode, the DTALIGN and PCDTOx are ignored, and data must be right aligned.

### 19.4.4.1 Oversampling of ordinary group of channels

The OOSRSEL bit in the ADC\_OVSP register can be used to resume interrupted ordinary oversampling mode.

- OOSRSEL=0: continuous conversion mode. Ordinary group of channels, after being interrupted by preempted group of channels during oversampling, will retain the converted data and resume from the last interrupted ordinary conversion.
- OOSRSEL=1: restart mode. Ordinary group of channels, after being interrupted by preempted group of channels during oversampling, will be reset and restart the ordinary conversion from the beginning.

*Figure 19-8* shows the differences between ordinary continuous mode and restart mode in 4x oversampling rate and sequence mode.

Figure 19-8 Ordinary oversampling restart mode selection



Trigger mode can be enabled by setting the OOSTREN bit in the ADC\_OVSP register. The user must trigger each of the ordinary conversions. In this mode, once the ordinary conversion is interrupted by preempted group of channels, it is necessary to re-trigger ordinary group of channels before resuming the oversampling of ordinary channels.

When the trigger mode works in conjunction with conversion sequence management mode, trigger mode is applied, and the conversion complete flag follows the conversion sequence management mode. [Figure 19-9](#) shows the behavior when the ordinary trigger mode works together with resume mode in 4x oversampling rate and sequential mode.

*Note: The trigger mode and repetition mode cannot be used concurrently.*

Figure 19-9 Ordinary oversampling trigger mode



#### 19.4.4.2 Oversampling of preempted group of channels

It is possible to use both the preempted oversampling and ordinary oversampling simultaneously or individually. The oversampling of the preempted group of channels does not affect ordinary oversampling modes. [Figure 19-10](#) shows the behavior when the preempted oversampling and ordinary oversampling trigger mode are used simultaneously in 4x oversampling rate and auto-conversion of preempted group.

Figure 19-10 Oversampling of preempted group of channels



## 19.4.5 Data management

At the end of the conversion of the ordinary group, the converted data are stored in the ADC\_ODT register. Once the preempted group conversion ends, the converted data of the preempted group are stored in the ADC\_PDTx register.

### 19.4.5.1 Data alignment

The DTALIGN bit in the ADC\_CTRL2 register is used to select the alignment mode of data (right-aligned or left-aligned). The offset value of ADC\_PCDTOx register is subtracted from the converted data of the preempted group. Thus the result may be a negative value, marked by SIGN.

Figure 19-11 Data alignment



### 19.4.5.2 Data read

Read access to the ADC\_ODT register using CPU or DMA gets the converted data of the ordinary group. Read access to the ADC\_PDTx register using CPU gets the converted data of the preempted group.

When the OCDMAEN bit is set in the ADC\_CTRL2 register, the ADC will issue a DMA request each time the ADC\_ODT register is updated.

## 19.4.6 Voltage monitoring

The OCVMEN bit or PCVMEN bit in the ADC\_CTRL1 register is used to enable voltage monitoring based on the converted data.

The VMOR bit will be set if the converted result is outside the high threshold (ADC\_VMHB register) or less than the low threshold (ADC\_VMLB register).

The VMSGGEN bit in the ADC\_CTRL1 register is used to enable voltage monitoring on either a single channel or all the channels. The VMCSEL bit is used to select a specific channel for voltage monitoring.

Voltage monitoring is based on the comparison result between the original converted data and the 12-bit voltage monitor boundary register, regardless of the PCDTOx and DTALIGN bits.

When using an oversampler, voltage monitoring is based on the comparison result of the 16-bit registers (ADC\_VMHB[15:0] and ADC\_VMLB[15:0]) vs. the oversampled data.

### 19.4.7 Status flag and interrupts

Each ADC has its dedicated ADC<sub>x</sub>\_STS register, namely, ordinary channel conversion start flag (OCCS), preempted channel conversion start flag (PCCS), preempted channel conversion end flag (PCCE), ordinary channel conversion end flag (CCE) and voltage monitor out of range (VMOR).

PCCE, CCE and VMOR have their respective interrupt enable bits. Once the interrupt bits are enabled, the corresponding flag is set and an interrupt is sent to CPU.

## 19.5 ADC registers

*Table 19-3* lists ADC register map and their reset values.

These peripheral registers must be accessed by words (32 bits).

Table 19-3 ADC register map and reset values

| Register   | Offset | Reset value |
|------------|--------|-------------|
| ADC_STS    | 0x000  | 0x0000 0000 |
| ADC_CTRL1  | 0x004  | 0x0000 0000 |
| ADC_CTRL2  | 0x008  | 0x0000 0000 |
| ADC_SPT1   | 0x00C  | 0x0000 0000 |
| ADC_SPT2   | 0x010  | 0x0000 0000 |
| ADC_PCDTO1 | 0x014  | 0x0000 0000 |
| ADC_PCDTO2 | 0x018  | 0x0000 0000 |
| ADC_PCDTO3 | 0x01C  | 0x0000 0000 |
| ADC_PCDTO4 | 0x020  | 0x0000 0000 |
| ADC_VMHB   | 0x024  | 0x0000 FFFF |
| ADC_VMLB   | 0x028  | 0x0000 0000 |
| ADC_OSQ1   | 0x02C  | 0x0000 0000 |
| ADC_OSQ2   | 0x030  | 0x0000 0000 |
| ADC_OSQ3   | 0x034  | 0x0000 0000 |
| ADC_PSQ    | 0x038  | 0x0000 0000 |
| ADC_PDT1   | 0x03C  | 0x0000 0000 |
| ADC_PDT2   | 0x040  | 0x0000 0000 |
| ADC_PDT3   | 0x044  | 0x0000 0000 |
| ADC_PDT4   | 0x048  | 0x0000 0000 |
| ADC_ODT    | 0x04C  | 0x0000 0000 |
| ADC_OVSP   | 0x080  | 0x0000 0000 |
| ADC_CCTRL  | 0x304  | 0x0000 0000 |

### 19.5.1 ADC status register (ADC\_STS)

Accessed by words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                              |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 5 | Reserved | 0x00000000  | resd | Kept at default value.                                                                                                                                                                                   |
| Bit 4     | OCCS     | 0x0         | rw0c | Ordinary channel conversion start flag<br>This bit is set by hardware and cleared by software (writing 0).<br>0: No ordinary channel conversion started<br>1: Ordinary channel conversion has started    |
| Bit 3     | PCCS     | 0x0         | rw0c | Preempted channel conversion start flag<br>This bit is set by hardware and cleared by software (writing 0).<br>0: No preempted channel conversion started<br>1: Preempted channel conversion has started |
| Bit 2     | PCCE     | 0x0         | rw0c | Preempted channel end of conversion flag<br>This bit is set by hardware and cleared by software (writing 0).<br>0: Conversion is not complete<br>1: Conversion is complete                               |
| Bit 1     | CCE      | 0x0         | rw0c | End of conversion flag<br>This bit is set by hardware. It is cleared by software (writing 0) or by reading the ADC_ODT register.<br>0: Conversion is not complete<br>1: Conversion is complete           |
| Bit 0     | VMOR     | 0x0         | rw0c | Voltage monitoring out of range flag<br>This bit is set by hardware and cleared by software (writing 0).<br>0: Voltage is within the value programmed<br>1: Voltage is outside the value programmed      |

### 19.5.2 ADC control register 1 (ADC\_CTRL1)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at default value.                                                                                                                                                                                        |
| Bit 23     | OCVMEN   | 0x0         | rw   | Voltage monitoring enable on ordinary channels<br>0: Voltage monitoring disabled on ordinary channels<br>1: Voltage monitoring enabled on ordinary channels                                                   |
| Bit 22     | PCVMEN   | 0x0         | rw   | Voltage monitoring enable on preempted channels<br>0: Voltage monitoring disabled on preempted channels<br>1: Voltage monitoring enabled on preempted channels                                                |
| Bit 21: 16 | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                        |
| Bit 15: 13 | OCPCNT   | 0x0         | rw   | Partitioned mode conversion count of ordinary channels<br>000: 1 channel<br>001: 2 channels<br>.....<br>111: 8 channels<br>Note: In this mode, the preempted group converts only one channel at each trigger. |
| Bit 12     | PCPEN    | 0x0         | rw   | Partitioned mode enable on preempted channels<br>0: Partitioned mode disabled on preempted channels<br>1: Partitioned mode enabled on preempted channels                                                      |
| Bit 11     | OCPEN    | 0x0         | rw   | Partitioned mode enable on ordinary channels<br>This is set and cleared by software to enable or disable partitioned mode on ordinary channels.<br>0: Partitioned mode disabled on ordinary channels          |

|          |          |      |    |                                                                                                                                                                                                                                                                                                                      |
|----------|----------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |      |    | 1: Partitioned mode enabled on ordinary channels                                                                                                                                                                                                                                                                     |
|          |          |      |    | Preempted group automatic conversion enable after ordinary group                                                                                                                                                                                                                                                     |
| Bit 10   | PCAUTOEN | 0x0  | rw | 0: Preempted group automatic conversion disabled<br>1: Preempted group automatic conversion enabled                                                                                                                                                                                                                  |
| Bit 9    | VMSGGEN  | 0x0  | rw | Voltage monitoring enable on a single channel<br>0: Disabled (Voltage monitoring enabled on all channels)<br>1: Enabled (Voltage monitoring enabled a single channel)                                                                                                                                                |
| Bit 8    | SQEN     | 0x0  | rw | Sequence mode enable<br>0: Sequence mode disabled (a single channel is converted)<br>1: Sequence mode enabled (the selected multiple channels are converted)<br>Note: If this mode is enabled and the CCEIEN/PCCEIEN is set, a CCE or PCCE interrupt is generated only at the end of conversion of the last channel. |
| Bit 7    | PCCEIEN  | 0x0  | rw | Conversion end interrupt enable on Preempted channels<br>0: Conversion end interrupt disabled on Preempted channels<br>1: Conversion end interrupt enabled on Preempted channels                                                                                                                                     |
| Bit 6    | VMORIEN  | 0x0  | rw | Voltage monitoring out of range interrupt enable<br>0: Voltage monitoring out of range interrupt disabled<br>1: Voltage monitoring out of range interrupt enabled                                                                                                                                                    |
| Bit 5    | CCEIEN   | 0x0  | rw | Channel conversion end interrupt enable<br>0: Channel conversion end interrupt disabled<br>1: Channel conversion end interrupt enabled                                                                                                                                                                               |
| Bit 4: 0 | VMCSEL   | 0x00 | rw | Voltage monitoring channel select<br>This filed is valid only when the VMSGGEN is enabled.<br>00000: ADC_IN0 channel<br>00001: ADC_IN1 channel<br>.....<br>01111: ADC_IN15 channel<br>10000: ADC_IN16 channel<br>10001: ADC_IN17 channel<br>10010~11111: Unused, do not configure.                                   |

### 19.5.3 ADC control register 2 (ADC\_CTRL2)

Accessed by words.

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                             |
|------------|-----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 30: 26 | Reserved  | 0x00        | resd | Kept at default value                                                                                                                                                                                                                                                   |
| Bit 23     | ITSRVEN   | 0x0         | rw   | Internal VINTRV enable<br>0: Internal VINTRV disabled<br>1: Internal VINTRV enabled                                                                                                                                                                                     |
| Bit 22     | OCSWTRG   | 0x0         | rw   | Conversion of ordinary channels triggered by software<br>0: Conversion of ordinary channels not triggered<br>1: Conversion of ordinary channels triggered (This bit is cleared by software or by hardware as soon as the conversion starts)                             |
| Bit 22     | PCSWTRG   | 0x0         | rw   | Conversion of preempted channels triggered by software<br>0: Conversion of preempted channels not triggered<br>1: Conversion of preempted channels triggered (This bit is cleared by software or by hardware as soon as the conversion starts)                          |
| Bit 20     | OCTEN     | 0x0         | rw   | Trigger mode enable for ordinary channels conversion<br>0: Trigger mode disabled for ordinary channels conversion<br>1: Trigger mode enabled for ordinary channels conversion                                                                                           |
| Bit 19: 17 | OCTESEL   | 0x0         | rw   | Trigger event select for ordinary channels conversion<br>000: Timer 1 TRGOUT event<br>001: Timer 1 CH4 event<br>010: Timer 2 TRGOUT event<br>011: Timer 3 TRGOUT event<br>100: Timer 9 TRGOUT event<br>101: Timer 1 CH1 event<br>110: EXINT 11<br>111: OCSWTRG          |
| Bit 16     | Reserved  | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                  |
| Bit 15     | PCTEN     | 0x00        | rw   | Trigger mode enable for preempted channels conversion<br>0: Trigger mode is disabled for preempted channels conversion<br>1: Trigger mode is enabled for preempted channels conversion                                                                                  |
| Bit 14:12  | PCTESEL   | 0x0         | rw   | Trigger event select for preempted channels conversion<br>000: Timer 1 CH2 event<br>001: Timer 1CH3 event<br>010: Timer 2 CH4 event<br>011: Timer 3 CH4 event<br>100: Timer 9 CH1 event<br>101: Timer 6 TRGOUT event<br>110: EXINT 15<br>111: PCSWTRG                   |
| Bit 10: 9  | Reserved  | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                  |
| Bit 8      | OCDMAEN   | 0x0         | rw   | DMA transfer enable of ordinary channels                                                                                                                                                                                                                                |
| Bit 7: 4   | Reserved  | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                  |
| Bit 3      | ADCALINIT | 0x0         | rw   | Initialize A/D calibration<br>This bit is set by software and cleared by hardware. It is cleared after the calibration registers are initialized.<br>0: No initialization occurred or initialization completed<br>1: Enable initialization or initialization is ongoing |
| Bit 2      | ADCAL     | 0x0         | rw   | A/D Calibration<br>0: No calibration occurred or calibration completed<br>1: Enable calibration or calibration is in process                                                                                                                                            |
| Bit 1      | RPEN      | 0x0         | rw   | Repetition mode enable<br>0: Repetition mode disabled<br>When SQEN=0, a single channel is converted each time                                                                                                                                                           |

---

|       |       |     |    |                                                                                                                                                                                                                                |
|-------|-------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | when a trigger event arrives; when SQEN=1, a group of channels are converted each timer when a trigger event arrives.                                                                                                          |
|       |       |     |    | 1: Repetition mode enabled<br>When SQEN =0, continuous conversion mode on a single channel is enabled at each trigger event; when SQEN =1, continuous conversion mode on a group of channels is enabled at each trigger event. |
| Bit 0 | ADCEN | 0x0 | rw | A/D converter enable<br>0: A/D converter disabled (ADC goes to power-down mode)<br>1: A/D converter enabled                                                                                                                    |
|       |       |     |    | Note:<br>When this bit is in OFF state, writing an ON command can wake up The ADC from power-down mode.<br>Note that there is a delay of t <sub>STAB</sub> between power up and start of conversion.                           |

---

#### 19.5.4 ADC sampling time register 1 (ADC\_SPT1)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                              |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:24  | Reserved | 0x00        | resd | Kept at default value.                                                                                                                                                                                   |
| Bit 23: 21 | CSPT17   | 0x0         | rw   | Sample time selection of channel ADC_IN17<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 20: 18 | CSPT16   | 0x0         | rw   | Sample time selection of channel ADC_IN16<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 17: 15 | CSPT15   | 0x0         | rw   | Sample time selection of channel ADC_IN15<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 14: 12 | CSPT14   | 0x0         | rw   | Sample time selection of channel ADC_IN14<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles                                                              |

---

|           |        |     |    |                                                                                                                                                                                                          |
|-----------|--------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |        |     |    | 101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles                                                                                                                                                |
| Bit 11: 9 | CSPT13 | 0x0 | rw | Sample time selection of channel ADC_IN13<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 8: 6  | CSPT12 | 0x0 | rw | Sample time selection of channel ADC_IN12<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 5: 3  | CSPT11 | 0x0 | rw | Sample time selection of channel ADC_IN11<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 2: 0  | CSPT10 | 0x0 | rw | Sample time selection of channel ADC_IN10<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |

## 19.5.5 ADC sampling time register 2 (ADC\_SPT2)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                             |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                   |
| Bit 29: 27 | CSPT9    | 0x0         | rw   | Sample time selection of channel ADC_IN9<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 26: 24 | CSPT8    | 0x0         | rw   | Sample time selection of channel ADC_IN8<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 23: 21 | CSPT7    | 0x0         | rw   | Sample time selection of channel ADC_IN7<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 20: 18 | CSPT6    | 0x0         | rw   | Sample time selection of channel ADC_IN6<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 17: 15 | CSPT5    | 0x0         | rw   | Sample time selection of channel ADC_IN5<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |

|            |       |     |    |                                                                                                                                                                                                         |
|------------|-------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |       |     |    | Sample time selection of channel ADC_IN4<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 14: 12 | CSPT4 | 0x0 | rw | Sample time selection of channel ADC_IN3<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 11: 9  | CSPT3 | 0x0 | rw | Sample time selection of channel ADC_IN2<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 8: 6   | CSPT2 | 0x0 | rw | Sample time selection of channel ADC_IN1<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 5: 3   | CSPT1 | 0x0 | rw | Sample time selection of channel ADC_IN0<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| Bit 2: 0   | CSPT0 | 0x0 | rw | Sample time selection of channel ADC_IN0<br>000: 1.5 cycles<br>001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |

## 19.5.6 ADC preempted channel data offset register x (ADC\_PCDTOx) (x=1..4)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                    |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x00000     | resd | Kept at default value                                                                                          |
| Bit 11: 0  | PCDTOx   | 0x000       | rw   | Data offset for Preempted channel x<br>Converted data stored in the ADC_PDTx = Raw converted data – ADC_PCDTOx |

## 19.5.7 ADC voltage monitoring high threshold register (ADC\_VWHB)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                      |
|------------|----------|-------------|------|----------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value            |
| Bit 15: 0  | VMHB     | 0xFFFF      | rw   | Voltage monitoring high boundary |

## 19.5.8 ADC voltage monitor low threshold register (ADC\_VWLB)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                     |
|------------|----------|-------------|------|---------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value           |
| Bit 15: 0  | VMLB     | 0x0000      | rw   | Voltage monitoring low boundary |

## 19.5.9 ADC ordinary sequence register 1 (ADC\_OSQ1)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                              |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at default value                                                                                                                                                                    |
|            |          |             |      | Ordinary conversion sequence length<br>0000: 1 conversion                                                                                                                                |
| Bit 23: 20 | OCLEN    | 0x0         | rw   | 0001: 2 conversions<br>.....<br>1111: 16 conversions                                                                                                                                     |
| Bit 19: 15 | OSN16    | 0x00        | rw   | Number of 16th conversion in ordinary sequence                                                                                                                                           |
| Bit 14: 10 | OSN15    | 0x00        | rw   | Number of 15th conversion in ordinary sequence                                                                                                                                           |
| Bit 9: 5   | OSN14    | 0x00        | rw   | Number of 14th conversion in ordinary sequence                                                                                                                                           |
| Bit 4: 0   | OSN13    | 0x00        | rw   | Number of 13th conversion in ordinary sequence<br>Note: The number can be 0~17 For example, if the number is set to 3, it means that the 13 <sup>th</sup> conversion is ADC_IN3 channel. |

## 19.5.10 ADC ordinary sequence register 2 (ADC\_OSQ2)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                    |
|------------|----------|-------------|------|------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at default value                          |
| Bit 29: 25 | OSN12    | 0x00        | rw   | Number of 12th conversion in ordinary sequence |
| Bit 24: 20 | OSN11    | 0x00        | rw   | Number of 11th conversion in ordinary sequence |
| Bit 19: 15 | OSN10    | 0x00        | rw   | Number of 10th conversion in ordinary sequence |
| Bit 14: 10 | OSN9     | 0x00        | rw   | Number of 9th conversion in ordinary sequence  |
| Bit 9: 5   | OSN8     | 0x00        | rw   | Number of 8th conversion in ordinary sequence  |

|          |      |      |    |                                                                                                                                                                                         |
|----------|------|------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 4: 0 | OSN7 | 0x00 | rw | Number of 7th conversion in ordinary sequence<br>Note: The number can be 0~17. For example, if the number is set to 8, it means that the 7 <sup>th</sup> conversion is ADC_IN8 channel. |
|----------|------|------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 19.5.11 ADC ordinary sequence register 3 (ADC\_OSQ3)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                   |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                         |
| Bit 29: 25 | OSN6     | 0x00        | rw   | Number of 6th conversion in ordinary sequence                                                                                                                                 |
| Bit 24: 20 | OSN5     | 0x00        | rw   | Number of 5th conversion in ordinary sequence                                                                                                                                 |
| Bit 19: 15 | OSN4     | 0x00        | rw   | Number of 4th conversion in ordinary sequence                                                                                                                                 |
| Bit 14: 10 | OSN3     | 0x00        | rw   | Number of 3rd conversion in ordinary sequence                                                                                                                                 |
| Bit 9: 5   | OSN2     | 0x00        | rw   | Number of 2nd conversion in ordinary sequence                                                                                                                                 |
| Bit 4: 0   | OSN1     | 0x00        | rw   | Number of 1st conversion in ordinary sequence<br>Note: The number can be 0~17. For example, if the number is set to 17, it means that the 1st conversion is ADC_IN17 channel. |

### 19.5.12 ADC preempted sequence register (ADC\_PSQ)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                                                |
|            |          |             |      | Preempted conversion sequence length<br>00: 1 conversion<br>01: 2 conversions<br>10: 3 conversions<br>11: 4 conversions                                                                                                                                                                                                                                                              |
| Bit 21: 20 | PCLEN    | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 19: 15 | PSN4     | 0x00        | rw   | Number of 4th conversion in preempted sequence                                                                                                                                                                                                                                                                                                                                       |
| Bit 14: 10 | PSN3     | 0x00        | rw   | Number of 3rd conversion in preempted sequence                                                                                                                                                                                                                                                                                                                                       |
| Bit 9: 5   | PSN2     | 0x00        | rw   | Number of 2nd conversion in preempted sequence                                                                                                                                                                                                                                                                                                                                       |
| Bit 4: 0   | PSN1     | 0x00        | rw   | Number of 1st conversion in preempted sequence<br>Note: The number can be 0~17. For example, if the number is set to 3, it refers to the ADC_IN3 channel.<br>If PCLEN is less than 4, the conversion sequence starts from 4-PCLEN. For example, when ADC_PSQ ([21: 0]) =10 00110 00101 00100 00011, it indicates that the scan conversion follows the sequence: 4, 5, 6, not 3, 4,5. |

### 19.5.13 ADC preempted data register x (ADC\_PDTx) (x=1..4)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                            |
|------------|----------|-------------|------|----------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value                  |
| Bit 15: 0  | PDTx     | 0x0000      | rw   | Conversion data from preempted channel |

### 19.5.14 ADC ordinary data register (ADC\_ODT)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                         |
|------------|----------|-------------|------|-------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value               |
| Bit 15: 0  | ODT      | 0x0000      | ro   | Conversion data of ordinary channel |

### 19.5.15 ADC oversampling register (ADC\_OVSP)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 11 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 10     | OOSRSEL  | 0x0         | rw   | Ordinary oversampling restart mode select<br>When the ordinary oversampling is interrupted by preempted conversions, this bit can be used to select where to resume ordinary conversions.<br>0: Continuous mode (ordinary oversampling buffer will be reserved)<br>1: Restart mode (ordinary oversampling buffer will be cleared, that is, the previously oversampled times are reset) |
| Bit 9      | OOSTREN  | 0x0         | rw   | Ordinary oversampling trigger mode enable<br>0: Disabled (only one trigger is needed for all oversampling conversions)<br>1: Enabled (Each oversampling conversion needs a trigger)                                                                                                                                                                                                    |
| Bit 8: 5   | OSSSEL   | 0x0         | rw   | Oversampling shift select<br>This field is used to define the number of right shift used in the oversampling results.<br>0000: No shift<br>0001: Shift 1 bit<br>0010: Shift 2 bits<br>0011: Shift 3 bits<br>0100: Shift 4 bits<br>0101: Shift 5 bits<br>0110: Shift 6 bits<br>0111: Shift 7 bits<br>1000: Shift 8 bits<br>1001~1111: Unused. Do not configure.                         |
| Bit 4: 2   | OSRSEL   | 0x0         | rw   | Oversampling ratio select<br>000: 2x<br>001: 4x<br>010: 8x<br>011: 16x<br>100: 32x<br>101: 64x<br>110: 128x<br>111: 256x                                                                                                                                                                                                                                                               |
| Bit 1      | POSEN    | 0x0         | rw   | Preempted oversampling enable<br>0: Preempted oversampling disabled<br>1: Preempted oversampling enabled                                                                                                                                                                                                                                                                               |
| Bit 0      | OOSEN    | 0x0         | rw   | Ordinary oversampling enable<br>0: Ordinary oversampling disabled<br>1: Ordinary oversampling enabled                                                                                                                                                                                                                                                                                  |

### 19.5.16 ADC common control register (ADC\_CCTRL)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                             |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                  |
| Bit 19: 16 | ADCDIV   | 0x0         | rw   | ADC division<br>0000: HCLK/2<br>0001: HCLK/3<br>...<br>1111: HCLK/17<br>Note:<br>The clock divided by this field is for ADC.<br>The maximum value of the ADCCLK is 28 MHz. After this division, the ADCCLK cannot be higher than PCLK2. |
| Bit 15:0   | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                  |

## 20 Controller area network (CAN)

### 20.1 CAN introduction

CAN (Controller Area Network) is a serial communication protocol for real-time and reliable data communication among nodes. It supports the CAN protocol versions 2.0A and 2.0B.

### 20.2 CAN main features

- Baud rates up to 1M bit/s  
*Note: the CAN protocol specifies that the maximum allowable tolerance for clock crystal is 1.58%. To avoid communication failure, an external crystal must be used as CAN clock source.*
- Supports time-triggered communication
- Interrupt enable and mask
- Configurable automatic retransmission mode

#### Transmission

- Three transmit mailboxes
- Configurable transmit priority
- Supports time stamp on transmission

#### Reception

- Two FIFOs with three-level depth
- 14 filter banks
- Supports the identifier list mode
- Supports the identifier mask mode
- FIFO overrun management

#### Time triggered communication mode

- 16-bit timers
- Time stamp on transmission

### 20.3 Baud rate

The nominal bit time of the CAN bus consists of three parts as follows:

**Synchronization segment (SYNC\_SEG):** This segment has one time unit, and its time duration is defined by the BRDIV[11: 0] bit in the CAN\_BTMG register.

**Bit segment 1 (BIT SEGMENT 1):** It is referred to as BSEG1 which contains the PROP\_SEG and PHASE\_SEG1 of the CAN standard. Its duration is configurable between 1 and 16 time units, depending on the BTS1[3: 0] bit.

**Big segment 2 (BIT SEGMENT 2):** It is referred to as BSEG2 which contains the PHASE\_SEG2 of the CAN standard. Its duration is configurable between 1 and 8 time units, depending on the BTS2[2: 0] bit.

Figure 20-1 Bit timing



**Baud rate formula:**

$$\text{BaudRate} = \frac{1}{\text{Nomal Bit Timimg}}$$

$$\text{Nomal Bit Timing} = t_{SYNC\_SEG} + t_{BSEG1} + t_{BSEG2}$$

with

$$t_{SYNC\_SEG} = 1 \times t_q$$

$$t_{BSEG1} = (1 + \text{BTS1}[3: 0]) \times t_q$$

$$t_{BSEG2} = (1 + \text{BTS2}[2: 0]) \times t_q$$

$$t_q = (1 + \text{BRDIV}[11: 0]) \times t_{pclk}$$

**Hard synchronization and resynchronization**

The start location of each bit in CAN nodes is always in synchronization segment by default. The sampling is performed at the edge location of the bit segment 1 and the big segment 2 simultaneously. During the actual transmission, there are certain phase drifts among the bits of CAN nodes due to the oscillator drifts among nodes, transmission latency and noise interference. Therefore it is necessary to avoid the impact on the communication by synchronizing on the start-bit edge and resynchronizing the following falling edges. The length of synchronization to compensate for phase drifts must not be greater than the resynchronization adjustment width (it is programmable between 1 and 4 time units through the RSAW[1:0] bit).

Figure 20-2 Frame type



## 20.4 Interrupt management

The CAN controller has four interrupt vectors that can be used to enable or disable interrupts by setting the CAN\_INTEN register.

Figure 20-3 Transmit interrupt generation



Figure 20-4 Receive interrupt 0 generation



Figure 20-5 Receive interrupt 1 generation



Figure 20-6 Status error interrupt generation



## 20.5 Design tips

The following information can be used as reference for CAN application development:

- **Debug control**

When the system enters the debug mode, the CAN controller stops or continues to work normally, depending on the CANx\_PAUSE bit in the DEBUG\_CTRL register or the PTD bit in the CAN\_MCTRL register.

- **Time triggered communication**

The timer triggered communication is used to improve the real-time performance so as to avoid bus competition or conflict. This feature is activated by setting TTCEN=1 in the CAN\_MCTRL register. The internal 16-bit timer is incremented at each CAN bit time, and it is sampled on the Start of Frame bit to generate a time stamp value, which is stored in the CAN\_RFCx and CAN\_TMCx register.

- **Register access protection**

The CAN\_BTMG register can be modified only when the CAN is in frozen mode.

Although the transmission of incorrect data will not cause problems at the network level, it can have severe impact on the application. Thus a transmit mailbox can be modified only when it is in empty state.

The filter configuration in the CAN\_FMCFG (filter mode configuration register), CAN\_FBWCFG (filter bit width configuration register) and CAN\_FRF (filter bit register) registers can be modified only when FCS=1. The CAN\_FiFBx register can be modified only when FCS=1 (in filter configuration mode) or FAENx=0 (filter is disabled).

## 20.6 Functional overview

### 20.6.1 General description

As the number of nodes and messages in the CAN network increases, an advanced filtering mechanism is needed to handle all types of messages in order to reduce the processing time of message reception. The FIFO scheme is used to ensure that the CPU can concentrate on application tasks for a long period of time without losing messages. In the meantime, the priority order of the messages to be transmitted is configured by hardware. Standard identifiers (11-bit) and extended identifiers (29-bit) are fully supported by hardware.

The CAN controller provides 14 scalable/configurable identifier filter banks, 2 receive FIFOs capable of storing 3 complete messages each and being completely managed by hardware, and 3 transmit mailboxes with their transmit priority order defined by the transmit scheduler.

Figure 20-7 CAN block diagram



## 20.6.2 Operating modes

The CAN controller has three operating modes:

- **Sleep mode**

After a system reset, the CAN controller is in Sleep mode. In this mode, the CAN clock is stopped to reduce power consumption and an internal pull-up resistance is disabled. However, the software can still access to the mailbox registers.

The software requests the CAN controller to enter Sleep mode by setting the DZEN bit in the CAN\_MCTRL register. The hardware confirms the request by setting the DZC bit in the CAN\_MSTS register.

**Exit Sleep mode in two ways:**

The CAN controller can be woke up by hardware clearing the DZEN bit when the AEDEN bit in the CAN\_MCTRL register and the CAN bus activity is detected. It can also be woke up by software clearing the DZEN bit.

**Sleep mode to Frozen mode:**

The CAN controller switches from Sleep mode to Frozen mode when the FZEN bit is set in the CAN\_MCTRL register and the DZEN bit is cleared. Such switch operation is confirmed by hardware setting the FZC bit in the CAN\_MSTS register.

**Sleep mode to Communication mode:**

The CAN controller enters Communication mode when the FZEN and DZEN bits are both cleared and the CAN controller has synchronized with the bus. In other words, it must wait for 11 consecutive recessive bits to be detected on the CANRX pin.

- **Frozen mode**

The software initialization can be done only in Frozen mode, including the CAN\_BTMG (CAN bit timing register) and CAN\_MCTRL (CAN master control register) registers. But the initialization of the 14 CAN filter banks (mode, scale, FIFO association, activation and filter values) can be done in non-Frozen mode. When the CAN controller is in Frozen mode, message reception and transmission are both disabled.

**Frozen mode to Communication mode:**

The CAN controller leaves Frozen mode when the FZEN bit is cleared in the CAN\_MCTRL register. This switch operation is confirmed by hardware clearing the FZC bit in the CAN\_MSTS register. The CAN controller must be synchronized with the bus.

**Frozen mode to Sleep mode:**

The CAN controller enters Sleep mode if DZEN=1 and FZEN=0 in the CAN\_MCTRL register. This switch operation is confirmed by hardware setting the DZC bit in the CAN\_MSTS register.

- **Communication mode**

After the CAN\_BTMG and CAN\_MCTRL registers are configured in Frozen mode, the CAN controller enters Communication mode and is ready for message reception and transmission.

**Communication mode to Sleep mode:**

The CAN controller switches to Sleep mode when the DZEN bit is set in the CAN\_MCTRL register and the current CAN bus transmission is complete.

**Communication mode to Frozen mode:** The CAN controller enters Frozen mode when the FZEN bit is set in the CAN\_MCTRL register and the current CAN bus transmission is complete.

## 20.6.3 Test modes

The CAN controller defines three test modes, including Listen-only mode, Loop back mode and Listen-only combined with Loop back mode. Test mode can be selected by setting the LOEN and LBEN bits in the CAN\_BTMG register.

- **Listen-only mode** is selected when the LOEN bit is set in the CAN\_BTMG register. In this mode, the CAN is able to receive data, but it sends only recessive bits on the CANTX pin. In the meantime, the dominant bits on the CANTX can be detected by the receive side but without affecting the CAN bus.
- **Loop back mode** is selected by setting the LBEN bit in the CAN\_BTMG register. In this mode, The CAN only receives the level signal on its CANTX pin of its own node. Meanwhile, the CAN can send data to the external bus. The Loop back mode is mainly used for self-test functions.
- **Loop back mode combined with Listen-only mode:** It is possible to combine the Listen-only and Loop back mode by setting [31:30] bits=11 in the CAN\_BTMG register. In this mode, the CAN is disconnected from the bus network, the CANTX pin remains in recessive state, and the transmit side is connected to the receive side.

## 20.6.4 Message filtering

The received message has to go through filtering by its identifier. If passed, the message will be stored in the corresponding FIFOs. If not, the message will be discarded. The whole operation is done by hardware without using CPU resources.

### Filter bit width

The CAN controller provides 14 configurable and scalable filter banks (0~13). Each filter bank has two 32-bit registers, CAN\_FiFB1 and CAN\_FiFB2. The filter bit width can be configured as two 16 bits or one 32 bits, depending on the corresponding bits in the CAN\_FBWCFG register.

**32-bit filter register CAN\_FiFBx includes the SID[10: 0], EID[17: 0], IDT and RTR bits.**

|                        |                  |                 |     |     |   |
|------------------------|------------------|-----------------|-----|-----|---|
| CAN_FiFB1[31: 21]      | CAN_FiFB1[20: 3] | CAN_FiFB1[2: 0] |     |     |   |
| CAN_FiFB2[31: 21]      | CAN_FiFB2[20: 3] | CAN_FiFB2[2: 0] |     |     |   |
| SID[10: 0]/EID[28: 18] | EID[17: 0]       |                 | IDT | RTR | 0 |

**Two 16-bit filter registers CAN\_FiFBx include SID[10: 0], IDT, RTR and EID[17: 15] bits**

|                               |                       |                       |                            |                     |                     |     |             |
|-------------------------------|-----------------------|-----------------------|----------------------------|---------------------|---------------------|-----|-------------|
| CAN_FiFB1[31: 21]<br>[20: 19] | CAN_FiFB1<br>[18: 16] | CAN_FiFB1<br>[18: 16] | CAN_FiFB1[15: 5]<br>[4: 3] | CAN_FiFB1<br>[4: 3] | CAN_FiFB1<br>[2: 0] |     |             |
| CAN_FiFB2[31: 21]<br>[20: 19] | CAN_FiFB2<br>[18: 16] | CAN_FiFB2<br>[18: 16] | CAN_FiFB2[15: 5]<br>[4: 3] | CAN_FiFB2<br>[4: 3] | CAN_FiFB2<br>[2: 0] |     |             |
| SID[10: 0]                    | IDT                   | RTR                   | EID[17: 15]                | SID[10: 0]          | IDT                 | RTR | EID[17: 15] |

### Filtering mode

The filter can be configured in identifier mask mode or in identifier list mode by setting the FMSELx bit in the CAN\_FMCFG register. The mask mode is used to specify which bits must match the pre-programmed identifiers, and which bits do not need. In identifier list mode, the identifier must match the pre-programmed identifier. The two modes can be used in conjunction with filter width to deliver four filtering modes below:

Figure 20-8 32-bit identifier mask mode

|         |                  |                 |                |
|---------|------------------|-----------------|----------------|
| ID      | CAN_FiFB1[31:21] | CAN_FiFB1[20:3] | CAN_FiFB1[2:0] |
|         | CAN_FiFB2[31:21] | CAN_FiFB2[20:3] | CAN_FiFB2[2:0] |
| Mask    | SID[10:0]        | EID[17:0]       | IDT RTR 0      |
| Mapping |                  |                 |                |

Figure 20-9 32-bit identifier list mode

|         |                  |                 |                    |
|---------|------------------|-----------------|--------------------|
| ID      | CAN_FiFB1[31:21] | CAN_FiFB1[20:3] | CAN_FiFB1<br>[2:0] |
| ID      | CAN_FiFB2[31:21] | CAN_FiFB2[20:3] | CAN_FiFB2<br>[2:0] |
| Mapping | SID[10:0]        | EID[17:0]       | IDT RTR 0          |

Figure 20-10 16-bit identifier mask mode

|         |                  |                  |            |
|---------|------------------|------------------|------------|
| ID      | CAN_FiFB1[15:5]  | CAN_FiFB1[4:0]   |            |
| Mask    | CAN_FiFB1[31:21] | CAN_FiFB1[20:16] |            |
| ID      | CAN_FiFB2[15:5]  | CAN_FiFB2[4:0]   |            |
| Mask    | CAN_FiFB2[31:21] | CAN_FiFB2[20:16] |            |
| Mapping | SID[10:0]        | RTR IDT          | EID[17:15] |

Figure 20-11 16-bit identifier list mode

|         |                  |                  |            |
|---------|------------------|------------------|------------|
| ID      | CAN_FiFB1[15:8]  | CAN_FiFB1[7:0]   |            |
| ID      | CAN_FiFB1[31:24] | CAN_FiFB1[23:16] |            |
| ID      | CAN_FiFB2[15:8]  | CAN_FiFB2[7:0]   |            |
| ID      | CAN_FiFB2[31:24] | CAN_FiFB2[23:16] |            |
| Mapping | SID[10:0]        | RTR IDT          | EID[17:15] |

### Filter match number

14 filter banks have different filtering effects dependent on the bit width mode. For example, 32-bit identifier mask mode contains the filters numbered n while 16-bit identifier list mode contains the filters numbered n, n+1, n+2 and n+3. When a frame of message passes through the filter number N, the number N is stored in the RFFMN[7: 0] bit in the CAN\_RFCx register. The distribution of the filter number does not take into account the activation state of the filter banks.

| Filter bank | FIFO0                  | Active | Filter number | Filter bank | FIFO1                 | Active | Filter number |
|-------------|------------------------|--------|---------------|-------------|-----------------------|--------|---------------|
| 0           | CAN_F0FB1[31:0]-ID     | Yes    | 0             | 3           | CAN_F3FB1[15:0]-ID    | Yes    | 0             |
|             | CAN_F0FB2[31:0]-ID     |        | 1             |             | CAN_F3FB1[31:16]-ID   |        | 1             |
|             | CAN_F1FB1[15:0]-ID     |        | 2             |             | CAN_F3FB2[15:0]-ID    |        | 2             |
|             | CAN_F1FB1[31:16]-ID    |        | 3             |             | CAN_F3FB2[31:16]-ID   |        | 3             |
| 1           | CAN_F1FB2[15:0]-ID     | Yes    | 4             | 4           | CAN_F4FB1[31:0]-ID    | Yes    | 4             |
|             | CAN_F1FB2[31:16]-ID    |        | 5             |             | CAN_F4FB2[31:0]-Mask  |        |               |
| 2           | CAN_F2FB1[31:0]-ID     | Yes    | 6             | 5           | CAN_F5FB1[15:0]-ID    |        | 5             |
|             | CAN_F2FB2[31:0]-Mask   |        |               |             | CAN_F5FB1[31:16]-Mask |        |               |
|             | CAN_F6FB1[15:0]-ID     |        | 7             |             | CAN_F5FB2[15:0]-ID    | No     |               |
|             | CAN_F6FB1[31:16]-Mask  | No     |               |             | CAN_F5FB2[31:16]-Mask |        | 6             |
| 6           | CAN_F6FB2[15:0]-ID     |        | 8             | 7           | CAN_F7FB1[15:0]-ID    |        | 7             |
|             | CAN_F6FB2[31:16]-Mask  |        |               |             | CAN_F7FB1[31:16]-ID   | No     | 8             |
| 9           | CAN_F9FB1[31:0]-ID     | No     | 9             |             | CAN_F7FB2[15:0]-ID    |        | 9             |
|             | CAN_F9FB2[31:0]-ID     |        | 10            |             | CAN_F7FB2[31:16]-ID   |        | 10            |
|             | CAN_F10FB1[15:0]-ID    |        |               | 8           | CAN_F8FB1[31:0]-ID    |        |               |
|             | CAN_F10FB1[31:16]-Mask |        | 11            |             | CAN_F8FB2[31:0]-Mask  | Yes    | 11            |
| 10          | CAN_F10FB2[15:0]-ID    | Yes    |               | 11          | CAN_F11FB1[31:0]-ID   |        | 12            |
|             | CAN_F10FB2[31:16]-Mask |        | 12            |             | CAN_F11FB2[31:0]-ID   | Yes    | 13            |
|             | CAN_F12FB1[15:0]-ID    |        | 13            |             | CAN_F13FB1[15:0]-ID   |        | 14            |
|             | CAN_F12FB1[31:16]-ID   |        | 14            |             | CAN_F13FB1[31:16]-ID  |        | 15            |
| 12          | CAN_F12FB2[15:0]-ID    | No     | 15            |             | CAN_F13FB2[15:0]-ID   | Yes    | 16            |
|             | CAN_F12FB2[31:16]-ID   |        | 16            |             | CAN_F13FB2[31:16]-ID  |        | 17            |

### Priority rules

It may occur that CAN controller receives a frame of message that pass through several filters successfully. In this case, the filter match number stored in the receive mailbox has its priority determined according to the following rules:

- A 32-bit filter has priority over a 16-bit filter
- For filters with equal bit width, the identifier list mode has priority over the identifier mask mode
- For filter with equal bit width and identifier mode, the lower number has priority over the higher number.

### Filter configuration

- Configure the CAN filters by setting the FCS bit in the CAN\_FCTRL register.
- Select Identifier mask mode or identifier list mode by setting the FMSELx bit in the CAN\_FMCFG register.
- Configure the filter bit width as two 16 bits or one 32 bits by setting the FBWSELx bit in the CAN\_FBWCFG register.
- Associate the filter x with FIFO0 or FIFO1 by setting the FRFSELx bit in the CAN\_FRF register.
- Activate the filter banks x by setting FAENx=1 in the CAN\_FACFG register.
- Configure 0~13 filter banks by writing to the CAN\_FiFBx register (i=0...27; x=1,2).

- Complete the CAN filter configuration by setting FCS=0 in the CAN\_FCTRL register.

## 20.6.5 Message transmission

### Register configuration

To transmit a message, the application must select one transmit mailbox and configure the CAN\_TMIx, CAN\_TMCx, CAN\_TMDTLx and CAN\_TMDTHx registers. Once the mailbox configuration is complete, setting the TMSR bit in the CAN\_TMIx register can initiate CAN transmission.

### Message transmission

The mailbox enters into pending state immediately after the mailbox is configured and the CAN controller receives a transmit request. At this point, the CAN controller will confirm whether the mailbox is given the highest priority or not. If yes, it will enter into SCHEDULED STATE; otherwise, it will wait to get the highest priority. The mailbox in SCHEDULED state will monitor the CAN bus state so that the messages in SCHEDULED mailbox can be transmitted as soon as the CAN bus becomes idle. The mailbox will enter EMPTY state at the end of the message transmission.

Figure 20-12 Transmit mailbox status



### Transmit priority configuration

When two or more transmit boxes are in PENDING state, their transmit priority must be given.

#### By identifier:

When MMSSR=0 in the CAN\_MCTRL register, the transmit order is defined by the identifier of the message in the mailbox. The message with lower identifier value has the highest priority. If the identifier values are the same, the message with lower mailbox number will be transmitted first.

#### By transmit request order:

When MMSSR=1 in the CAN\_MCTRL register, the transmit priority is given by the transmit request order of mailboxes.

### Transmit status and error status

The TMxTCF, TMxTSF, TMxALF, TMxTEF and TMxEF bits in the CAN\_TSTS register are used to indicate transmit status and error status.

TMxTCF bit: Transmission complete flag, indicating that the data transmission is complete when TMxTCF=1.

TMxTSF bit: Transmission success flag, indicating that the data has been transmitted successfully when TMxTSF =1.

TMxALF bit: Transmission arbitration lost flag, indicating that the data transmission arbitration is lost when TMxALF=1.

TMxTEF bit: Transmission error flag, indicating that the data transmission failed due to bus error, and an error frame is sent when TMxTEF=1.

TMxEF bit: Mailbox empty flag, indicating that no message is pending for transmission in the mailbox. This bit is valid when set to 1.

### Transmit abort

The TMxCT bit is set in the CAN\_TSTS register to abort the transmission of the current mailbox, detailed as follows:

When the current transmission fails or arbitration is lost, if the automatic retransmission mode is disabled, the transmit mailbox become EMPTY; if the automatic retransmission mode is enabled, the transmit mailbox becomes SCHEDULED, the mailbox transmission then is aborted and becomes EMPTY.

When the current transmission is complete successfully, the mailbox becomes EMPTY.

## 20.6.6 Message reception

### Register configuration

The CAN\_RFIdx (receive FIFO mailbox identifier register), CAN\_RFCx (receive FIFO mailbox data length and time stamp register), CAN\_RFDTLx (receive FIFO mailbox data register low) and CAN\_RFDTTx (receive FIFO mailbox data register high) registers can be used by user applications to obtain valid messages.

### Message reception

The CAN controller has two FIFO with three levels to receive messages. FIFO rule is adopted. When the message is received correctly and has passed the identifier filtering, it is considered as a valid message and is stored in the corresponding FIFO. The number of the received messages RFxMN[1: 0] will be incremented by one whenever the receive FIFO receives a valid message. If a valid message is received when RFxMN[1: 0]=3, the controller will select either to overwrite the previous messages or discard the new incoming message through the MDRSEL bit in the CAN\_MCTRL register.

In the meantime, when the user reads a frame of message and the RFxR is set in the CAN\_RFx register, one FIFO mailbox is released, and RFxMN[1: 0] bit is decremented by one in the CAN\_RFx register.

### Receive FIFO status

RFxMN[1: 0], RFxFF and RFxOF bits in the RFx register are used to indicate the status of receive FIFO.

RFxMN[1: 0]: indicates the number of valid messages stored in the FIFOx.

RFxFF: indicates that three valid messages are stored in the FIFOx (i.e. the three mailboxes are full), as shown in (c) of [Figure 20-13](#).

RFxOF: indicates that a new valid message has been received while the FIFOx is full, as shown in (d) of [Figure 20-13](#).

[Figure 20-13 Receive FIFO status](#)



## 20.6.7 Error management

The status of the current CAN node is indicated by the receive error counter (TEC) and transmit error counter (REC) bits in the CAN\_ESTS register. The ETR[6: 4] bit in the CAN\_ESTS register is used to record the last error source, and the corresponding interrupts will be generated when the CAN\_INTEN register is enabled.

- **Error active flag:** When both TEC and REC are lower than 128, the system is in the error active state. An error active flag is set when an error is detected.
- **Error passive flag:** When either TEC or REC is greater than 127, the system is in the error passive state. An error passive flag is set when an error is detected.
- **Bus-off state:** The bus-off state is entered when TEC is greater than 255. In bus-off state, the node is not able to transmit and receive messages. The CAN recovers from bus-off state in two ways:

Option 1: When AEBOEN=0 in the CAN\_MCTRL register, in communication mode, the CAN will recover from bus-off state when the 128 occurrence of 11 consecutive recessive bits are detected on the CAN RX pin, and the software requests to enter Frozen mode and exit Frozen mode.

Option 2:

When AEBOEN=1 in the CAN\_MCTRL register, in communication mode, the CAN will resume from bus-off state automatically after 128 occurrences of 11 consecutive recessive bits have been detected on the CAN RX pin.

## 20.7 CAN registers

These peripheral registers must be accessed by words (32 bits).

Table 20-1 CAN register map and reset values

| Register | Offset    | Reset value |
|----------|-----------|-------------|
| MCTRL    | 000h      | 0x0001 0002 |
| MSTS     | 004h      | 0x0000 0C02 |
| TSTS     | 008h      | 0x1C00 0000 |
| RF0      | 00Ch      | 0x0000 0000 |
| FR1      | 010h      | 0x0000 0000 |
| INTEN    | 014h      | 0x0000 0000 |
| ESTS     | 018h      | 0x0000 0000 |
| BTMG     | 01Ch      | 0x0123 0000 |
| Reserved | 020h~17Fh | xx          |
| TMIO     | 180h      | 0xFFFF XXXX |
| TMC0     | 184h      | 0xFFFF XXXX |
| TMDTL0   | 188h      | 0xFFFF XXXX |
| TMDTH0   | 18Ch      | 0xFFFF XXXX |
| TMI1     | 190h      | 0xFFFF XXXX |
| TMC1     | 194h      | 0xFFFF XXXX |
| TMDTL1   | 198h      | 0xFFFF XXXX |
| TMDTH1   | 19Ch      | 0xFFFF XXXX |
| TMI2     | 1A0h      | 0xFFFF XXXX |
| TMC2     | 1A4h      | 0xFFFF XXXX |
| TMDTL2   | 1A8h      | 0xFFFF XXXX |
| TMDTH2   | 1ACh      | 0xFFFF XXXX |

|          |           |             |
|----------|-----------|-------------|
| RFI0     | 1B0h      | 0XXXXX XXXX |
| RFC0     | 1B4h      | 0XXXXX XXXX |
| RFDTL0   | 1B8h      | 0XXXXX XXXX |
| RFDTH0   | 1BCh      | 0XXXXX XXXX |
| RFI1     | 1C0h      | 0XXXXX XXXX |
| RFC1     | 1C4h      | 0XXXXX XXXX |
| RFDTL1   | 1C8h      | 0XXXXX XXXX |
| RFDTH1   | 1CCh      | 0XXXXX XXXX |
| Reserved | 1D0h~1FFh | xx          |
| FCTRL    | 200h      | 0x2A1C 0E01 |
| FMCFG    | 204h      | 0x0000 0000 |
| Reserved | 208h      | xx          |
| FBWCFG   | 20Ch      | 0x0000 0000 |
| Reserved | 210h      | xx          |
| FRF      | 214h      | 0x0000 0000 |
| Reserved | 218h      | xx          |
| FACFG    | 21Ch      | 0x0000 0000 |
| Reserved | 220h~23Fh | xx          |
| F0FB1    | 240h      | 0XXXXX XXXX |
| F0FB2    | 244h      | 0XXXXX XXXX |
| F1FB1    | 248h      | 0XXXXX XXXX |
| F1FB2    | 24Ch      | 0XXXXX XXXX |
| ...      | ...       | ...         |
| F13FB1   | 2A8h      | 0XXXXX XXXX |
| F13FB2   | 2ACh      | 0XXXXX XXXX |

## 20.7.1 CAN control and status registers

### 20.7.1.1 CAN master control register (CAN\_MCTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 16     | PTD      | 0x1         | rw   | <p>Prohibit trans when debug<br/>0: Transmission works during debug<br/>1: Transmission is prohibited during debug. Receive FIFO can be still accessible normally.</p> <p>Note: Transmission can be disabled only when PTD and CANx_PAUSE bits in the DEBUG_CTRL register are set simultaneously.</p>                                                                                                                                                                                       |
| Bit 15     | SPRST    | 0x0         | rw1s | <p>Software partial reset<br/>0: Normal<br/>1: Software partial reset</p> <p>Note:<br/>SPRST only reset receive FIFO and MCTRL register.<br/>The CAN enters Sleep mode after reset. Then this bit is automatically cleared by hardware.</p>                                                                                                                                                                                                                                                 |
| Bit 14: 8  | Reserved | 0x00        | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 7      | TTCEN    | 0x0         | rw   | <p>Time triggered communication mode enable<br/>0: Time triggered communication mode disabled<br/>1: Time triggered communication mode enabled</p>                                                                                                                                                                                                                                                                                                                                          |
| Bit 6      | AEBOEN   | 0x0         | rw   | <p>Automatic exit bus-off enable<br/>0: Automatic exit bus-off disabled<br/>1: Automatic exit bus-off enabled</p> <p>Note:<br/>When Automatic exit bus-off mode is enabled, the hardware will automatically leave bus-off mode as soon as an exit timing is detected on the CAN bus.<br/>When Automatic exit bus-off mode is disabled, the software must enter/leave the freeze mode once more, and then the bus-off state is left only when an exit timing is detected on the CAN bus.</p> |
| Bit 5      | AEDEN    | 0x0         | rw   | <p>Automatic exit doze mode enable<br/>0: Automatic exit sleep mode disabled<br/>1: Automatic exit sleep mode enabled</p> <p>Note:<br/>When Automatic exit sleep mode is disabled, the Sleep mode is left by software clearing the sleep request command.<br/>When Automatic exit sleep mode is enabled, the sleep mode is left without the need of software intervention as soon as a message is monitored on the CAN bus.</p>                                                             |
| Bit 4      | PRSFEN   | 0x0         | rw   | <p>Prohibit retransmission enable when sending fails enable<br/>0: Retransmission is enabled.<br/>1: Retransmission is disabled.</p>                                                                                                                                                                                                                                                                                                                                                        |
| Bit 3      | MDRSEL   | 0x0         | rw   | <p>Message discard rule select when overflow<br/>0: The previous message is discarded.<br/>1: The new incoming message is discarded.</p>                                                                                                                                                                                                                                                                                                                                                    |
| Bit 2      | MMSSR    | 0x0         | rw   | <p>Multiple message transmit sequence rule<br/>0: The message with the smallest identifier is first transmitted.<br/>1: The message with the first request order is first transmitted.</p>                                                                                                                                                                                                                                                                                                  |
| Bit 1      | DZEN     | 0x1         | rw   | <p>Doze mode enable<br/>0: Sleep mode is disabled.<br/>1: Sleep mode is enabled.</p> <p>Note:<br/>The hardware will automatically leave sleep mode when the AEDEN is set and a message is monitored on the CAN bus.</p> <p>After CAN reset or partial software reset, this bit is forced</p>                                                                                                                                                                                                |

|       |      |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |    | to be set by hardware, that is, the CAN will keep in sleep mode, by default.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |      |     |    | Freeze mode enable<br>0: Freeze mode disabled<br>1: Freeze mode enabled<br><br>Note:<br>The CAN leaves Freeze mode once 11 consecutive recessive bits have been detected on the RX pin. For this reason, the software acknowledges the entry of Freeze mode after the FZC bit is cleared by hardware.<br>The Freeze mode is entered only when the current CAN activity (transmission or reception) is completed. Thus the software acknowledges the exit of Freeze mode after the FZC bit is cleared by hardware. |
| Bit 0 | FZEN | 0x0 | rw |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 20.7.1.2 CAN master status register (CAN\_MSTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x00000     | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 11     | REALRX   | 0x1         | ro   | Real time level on RX pin<br>0: Low<br>1: High                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 10     | LSAMPRX  | 0x1         | ro   | Last sample level on RX pin<br>0: Low<br>1: High<br>Note: This value keeps updating with the REALRX.                                                                                                                                                                                                                                                                                                                   |
| Bit 9      | CURS     | 0x0         | ro   | Current receive status<br>0: No reception occurs<br>1: Reception is in progress<br>Note: This bit is set by hardware when the CAN reception starts, and it is cleared by hardware at the end of reception.                                                                                                                                                                                                             |
| Bit 8      | CUSS     | 0x0         | ro   | Current transmit status<br>0: No transmit occurs<br>1: Transmit is in progress<br>Note: This bit is set by hardware when the CAN transmission starts, and it is cleared by hardware at the end of transmission.                                                                                                                                                                                                        |
| Bit 7: 5   | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 4      | EDZIF    | 0x0         | rw1c | Enter doze mode interrupt flag<br>0: Sleep mode is not entered or no condition for flag set.<br>1: Sleep mode is entered.<br>Note:<br>This bit is set by hardware only when EDZIEN=1 and the CAN enters Sleep mode. When set, this bit will generate a status change interrupt. This bit is cleared by software (writing 1 to itself) or by hardware when DZC is cleared.                                              |
| Bit 3      | QDZIF    | 0x0         | rw1c | Exit doze mode interrupt flag<br>0: Sleep mode is not left or no condition for exit.<br>1: Sleep mode has been left or exit condition has generated.<br>Note:<br>This bit is cleared by software (writing 1 to itself)<br>Sleep mode is left when a SOF is detected on the bus.<br>When QDZIEN=1, this bit will generate a status change interrupt.                                                                    |
| Bit 2      | EOIF     | 0x0         | rw1c | Error occur interrupt flag<br>0: No error interrupt or no condition for error interrupt flag<br>1: Error interrupt is generated.<br>Note:<br>This bit is cleared by software (writing 1 to itself).<br>This bit is set by hardware only when the corresponding bit is set in the CAN_ESTS register and the corresponding interrupt enable bit in the CAN_INTEN register is enabled. When set, this bit will generate a |

|       |     |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     |    | status change interrupt.                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |     |     |    | Doze mode acknowledge<br>0: The CAN is not in Sleep mode.<br>1: CAN is in Sleep mode.<br>Note:<br>This bit is used to decide whether the CAN is in Sleep mode or not. This bit acknowledges the Sleep mode request generated by software.                                                                                                                                                                                           |
| Bit 1 | DZC | 0x1 | ro | The Sleep mode can be entered only when the current CAN activity (transmission or reception) is completed. For this reason, the software acknowledges the entry of Sleep mode after this bit is set by hardware.<br>The Sleep mode is left only once 11 consecutive recessive bits have been detect on the CAN RX pin. For this reason, the software acknowledges the exit of Sleep mode after this bit is cleared by hardware.     |
|       |     |     |    | Freeze mode confirm<br>0: The CAN is not in Freeze mode.<br>1: The CAN is in Freeze mode.<br>Note:<br>This bit is used to decide whether the CAN is in Freeze mode or not. This bit acknowledges the Freeze mode request generated by software.                                                                                                                                                                                     |
| Bit 0 | FZC | 0x0 | ro | The Freeze mode can be entered only when the current CAN activity (transmission or reception) is completed. For this reason, the software acknowledges the entry of Freeze mode after this bit is set by hardware.<br>The Freeze mode is left only once 11 consecutive recessive bits have been detect on the CAN RX pin. For this reason, the software acknowledges the exit of Freeze mode after this bit is cleared by hardware. |

### 20.7.1.3 CAN transmit status register (CAN\_TSTS)

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                      |
|------------|--------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | TM2LPF | 0x0         | ro   | Transmit mailbox 2 lowest priority flag<br>0: Mailbox 2 is not given the lowest priority.<br>1: Lowest priority (This indicates that more than one mailboxes are pending for transmission, the mailbox 2 has the lowest priority.)                               |
| Bit 30     | TM1LPF | 0x0         | ro   | Transmit mailbox 1 lowest priority flag<br>0: Mailbox 1 is not given the lowest priority.<br>1: Lowest priority (This indicates that more than one mailboxes are pending for transmission, the mailbox 1 has the lowest priority.)                               |
| Bit 29     | TM0LPF | 0x0         | ro   | Transmit mailbox 0 lowest priority flag<br>0: Mailbox 0 is not given the lowest priority.<br>1: Lowest priority (This indicates that more than one mailboxes are pending for transmission, the mailbox 0 has the lowest priority.)                               |
| Bit 28     | TM2EF  | 0x1         | ro   | Transmit mailbox 2 empty flag<br>This bit is set by hardware when no transmission is pending in the mailbox 2.                                                                                                                                                   |
| Bit 27     | TM1EF  | 0x1         | ro   | Transmit mailbox 1 empty flag<br>This bit is set by hardware when no transmission is pending in the mailbox 1.                                                                                                                                                   |
| Bit 26     | TM0EF  | 0x1         | ro   | Transmit mailbox 0 empty flag<br>This bit is set by hardware when no transmission is pending in the mailbox 0.                                                                                                                                                   |
| Bit 25: 24 | TMNR   | 0x0         | ro   | Transmit Mailbox number record<br>Note:<br>If the transmit mailbox is free, these two bits refer to the number of the next transmit mailbox free.<br>For example, in case of free CAN, the value of these two bit becomes 01 after a message transmit request is |

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |     |      | written.<br>If the transmit box is full, these two bits refer to the number of the transmit mailbox with the lowest priority. For example, when there are three messages are pending for transmission, the identifiers of mailbox 0, mailbox 1 and mailbox 2 are 0x400, 0x433 and 0x411 respectively, and the value of these two bits becomes 01.                                                                             |
| Bit 23     | TM2CT    | 0x0 | ro   | Transmit mailbox 2 cancel transmit<br>0: No effect<br>1: Transmission is cancelled.<br><br>Note: Software sets this bit to abort the transmission of mailbox 2. This bit is cleared by hardware when the transmit message in the mailbox 2 is cleared. Setting this bit has no effect if the mailbox 2 is free.                                                                                                               |
| Bit 22: 20 | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 19     | TM2TEF   | 0x0 | rw1c | Transmit mailbox 2 transmission error flag<br>0: No error<br>1: Mailbox 2 transmission error<br><br>Note:<br>This bit is set when the mailbox 2 transmission error occurred.<br>It is cleared by software writing 1 or by hardware at the start of the next transmission                                                                                                                                                      |
| Bit 18     | TM2ALF   | 0x0 | rw1c | Transmit mailbox 2 arbitration lost flag<br>0: No arbitration lost<br>1: Transmit mailbox 2 arbitration lost<br><br>Note:<br>This bit is set when the mailbox 2 transmission failed due to an arbitration lost.<br>It is cleared by software writing 1 or by hardware at the start of the next transmission                                                                                                                   |
| Bit 17     | TM2TSF   | 0x0 | rw1c | Transmit mailbox 2 transmission success flag<br>0: Transmission failed<br>1: Transmission was successful.<br><br>Note:<br>This bit indicates whether the mailbox 2 transmission is successful or not. It is cleared by software writing 1.                                                                                                                                                                                    |
| Bit 16     | TM2TCF   | 0x0 | rw1c | Transmit mailbox 2 transmission completed flag<br>0: Transmission is in progress<br>1: Transmission is completed<br><br>Note:<br>This bit is set by hardware when the transmission/abort request on mailbox 2 has been completed.<br>It is cleared by software writing 1 or by hardware when a new transmission request is received.<br>Clearing this bit will clear the TSMF2, ALMF2 and TEMF2 bits of mailbox 2 by hardware |
| Bit 15     | TM1CT    | 0x0 | rw1s | Transmit mailbox 1 cancel transmit<br>0: No effect<br>1: Mailbox 1 cancel transmit<br><br>Note: This bit is set by software to abort the transmission request on mailbox 1. Clearing the message transmission on mailbox 1 will clear this bit. Setting by this software has no effect when the mailbox 1 is free.                                                                                                            |
| Bit 14: 12 | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 11     | TM1TEF   | 0x0 | rw1c | Transmit mailbox 1 transmission error flag<br>0: No error<br>1: Mailbox 1 transmission error<br><br>Note:<br>This bit is set when the mailbox 1 transmission error occurred.<br>It is cleared by software writing 1 or by hardware at the start of the next transmission                                                                                                                                                      |
| Bit 10     | TM1ALF   | 0x0 | rw1c | Transmit mailbox 1 arbitration lost flag                                                                                                                                                                                                                                                                                                                                                                                      |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 0: No arbitration lost<br>1: Transmit mailbox 1 arbitration lost<br><b>Note:</b><br>This bit is set when the mailbox 1 transmission failed due to an arbitration lost.<br>It is cleared by software writing 1 or by hardware at the start of the next transmission                                                                                                                                                    |
| Bit 9    | TM1TSF   | 0x0 | rw1c | Transmit mailbox 1 transmission success flag<br>0: Transmission failed<br>1: Transmission was successful.<br><b>Note:</b><br>This bit indicates whether the mailbox 1 transmission is successful or not. It is cleared by software writing 1.                                                                                                                                                                         |
| Bit 8    | TM1TCF   | 0x0 | rw1c | Transmit mailbox 1 transmission completed flag<br>0: Transmission is in progress<br>1: Transmission is completed<br><b>Note:</b><br>This bit is set by hardware when the transmission/abort request on mailbox 1 has been completed.<br>It is cleared by software writing 1 or by hardware when a new transmission request is received.<br>Clearing this bit will clear the TSMF1, ALMF1 and TEMF1 bits of mailbox 1. |
| Bit 7    | TM0CT    | 0x0 | rw1s | Transmit mailbox 0 cancel transmit<br>0: No effect<br>1: Mailbox 0 cancel transmit<br><b>Note:</b> This bit is set by software to abort the transmission request on mailbox 0. Clearing the message transmission on mailbox 0 will clear this bit. Setting by this software has no effect when the mailbox 0 is free.                                                                                                 |
| Bit 6: 4 | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 3    | TM0TEF   | 0x0 | rw1c | Transmit mailbox 0 transmission error flag<br>0: No error<br>1: Mailbox 0 transmission error<br><b>Note:</b><br>This bit is set when the mailbox 0 transmission error occurred.<br>It is cleared by software writing 0 or by hardware at the start of the next transmission                                                                                                                                           |
| Bit 2    | TM0ALF   | 0x0 | rw1c | Transmit mailbox 0 arbitration lost flag<br>0: No arbitration lost<br>1: Transmit mailbox 0 arbitration lost<br><b>Note:</b><br>This bit is set when the mailbox 0 transmission failed due to an arbitration lost.<br>It is cleared by software writing 1 or by hardware at the start of the next transmission                                                                                                        |
| Bit 1    | TM0TSF   | 0x0 | rw1c | Transmit mailbox 0 transmission success flag<br>0: Transmission failed<br>1: Transmission was successful.<br><b>Note:</b><br>This bit indicates whether the mailbox 0 transmission is successful or not. It is cleared by software writing 1.                                                                                                                                                                         |
| Bit 0    | TM0TCF   | 0x0 | rw1c | Transmit mailbox 0 transmission completed flag<br>0: Transmission is in progress<br>1: Transmission is completed<br><b>Note:</b><br>This bit is set by hardware when the transmission/abort request on mailbox 0 has been completed.<br>It is cleared by software writing 1 or by hardware when a new transmission request is received.<br>Clearing this bit will clear the TSMF0, ALMF0 and TEMF0 bits of mailbox 0. |

### 20.7.1.4 CAN receive FIFO 0 register (CAN\_RF0)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 6 | Reserved | 0x00000000  | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                 |
|           |          |             |      | Receive FIFO 0 release<br>0: No effect<br>1: Release FIFO<br>Note:<br>This bit is set by software to release FIFO 0. It is cleared by hardware when the FIFO 0 is released.<br>Setting this bit by software has no effect when the FIFO 0 is empty.<br>If there are more than two messages pending in the FIFO 0, the software has to release the FIFO 0 to access the second message. |
| Bit 5     | RF0R     | 0x0         | rw1s | Receive FIFO 0 overflow flag<br>0: No overflow<br>1: Receive FIFO 0 overflow<br>Note:<br>This bit is set by hardware when a new message has been received and passed the filter while the FIFO 0 is full.<br>It is cleared by software by writing 1.                                                                                                                                   |
| Bit 4     | RF0OF    | 0x0         | rw1c | Receive FIFO 0 full flag<br>0: Receive FIFO 0 is not full<br>1: Receive FIFO 0 is full<br>Note:<br>This bit is set by hardware when there are three messages pending in the FIFO 0.<br>It is cleared by software by writing 1.                                                                                                                                                         |
| Bit 3     | RF0FF    | 0x0         | rw1c | Receive FIFO 0 message num<br>Note:<br>These two bits indicate how many messages are pending in the FIFO 0.                                                                                                                                                                                                                                                                            |
| Bit 2     | Reserved | 0x0         | resd | RF0ML bit is incremented by one each time a new message has been received and passed the filter while the FIFO 0 is not full.<br>RF0ML bit is decremented by one each time the software releases the receive FIFO 0 by writing 1 to the RF0R bit.                                                                                                                                      |
| Bit 1: 0  | RF0MN    | 0x0         | ro   |                                                                                                                                                                                                                                                                                                                                                                                        |

### 20.7.1.5 CAN receive FIFO 1 register (CAN\_RF1)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 6 | Reserved | 0x00000000  | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                         |
|           |          |             |      | Receive FIFO 1 release<br>0: No effect<br>1: Release FIFO<br>Note:<br>This bit is set by software to release receive FIFO 1. It is cleared by hardware when the FIFO 1 is released.<br>Setting this bit by software has no effect when the FIFO 1 is empty.<br>If there are more than two messages pending in the FIFO 0, the software has to release the FIFO 1 to access the second message. |
| Bit 5     | RF1R     | 0x0         | rw1s | Receive FIFO 1 overflow flag<br>0: No overflow<br>1: Receive FIFO 1 overflow<br>Note:<br>This bit is set by hardware when a new message has been received and passed the filter while the FIFO 1 is full.<br>It is cleared by software by writing 1.                                                                                                                                           |
| Bit 4     | RF1OF    | 0x0         | rw1c | Receive FIFO 1 full flag                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 3     | RF1FF    | 0x0         | rw1c |                                                                                                                                                                                                                                                                                                                                                                                                |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                         |
|----------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 0: Receive FIFO 1 is not full<br>1: Receive FIFO 1 is full<br><b>Note:</b><br>This bit is set by hardware when three messages are pending in the FIFO 1.<br>It is cleared by software by writing 1.                                                                                                                                                                     |
| Bit 2    | Reserved | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                  |
| Bit 1: 0 | RF1MN    | 0x0 | ro   | Receive FIFO 1 message num<br><b>Note:</b><br>These two bits indicate how many messages are pending in the FIFO 1.<br>RF1ML bit is incremented by one each time a new message has been received and passed the filter while the FIFO 1 is not full.<br>RF1ML bit is decremented by one each time the software releases the receive FIFO 1 by writing 1 to the RF1R bit. |
|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                         |

### 20.7.1.6 CAN interrupt enable register (CAN\_INTEN)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                           |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 18 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                |
| Bit 17     | EDZIEN   | 0x0         | rw   | Enter doze mode interrupt enable<br>0: Enter sleep mode interrupt disabled<br>1: Enter sleep mode interrupt enabled<br><b>Note:</b> EDZIF flag bit corresponds to this interrupt. An interrupt is generated when both this bit and EDZIF bit are set. |
| Bit 16     | QDZIEN   | 0x0         | rw   | Quit doze mode interrupt enable<br>0: Quit sleep mode interrupt disabled<br>1: Quit sleep mode interrupt enabled<br><b>Note:</b> The flag bit of this interrupt is the QDZIF bit. An interrupt is generated when both this bit and QDZIF bit are set. |
| Bit 15     | EOIEN    | 0x0         | rw   | Error occur interrupt enable<br>0: Error interrupt disabled<br>1: Error interrupt enabled<br><b>Note:</b> The flag bit of this interrupt is the EOIF bit. An interrupt is generated when both this bit and EOIF bit are set.                          |
| Bit 14: 12 | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                |
| Bit 11     | ETRIEN   | 0x0         | rw   | Error type record interrupt enable<br>0: Error type record interrupt disabled<br>1: Error type record interrupt enabled<br><b>Note:</b> EOIF is set only when this interrupt is enabled and the ETR[2: 0] is set by hardware.                         |
| Bit 10     | BOIEN    | 0x0         | rw   | Bus-off interrupt enable<br>0: Bus-off interrupt disabled<br>1: Bus-off interrupt enabled<br><b>Note:</b> EOIF is set only when this interrupt is enabled and the BOF is set by hardware.                                                             |
| Bit 9      | EPIEN    | 0x0         | rw   | Error passive interrupt enable<br>0: Error passive interrupt disabled<br>1: Error passive interrupt enabled<br><b>Note:</b> EOIF is set only when this interrupt is enabled and the EPF is set by hardware.                                           |
| Bit 8      | EAIEN    | 0x0         | rw   | Error active interrupt enable<br>0: Error warning interrupt disabled<br>1: Error warning interrupt enabled<br><b>Note:</b> EOIF is set only when this interrupt is enabled and the EAF is set by hardware.                                            |
| Bit 7      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                |
| Bit 6      | RF1OIEN  | 0x0         | rw   | Receive FIFO 1 overflow interrupt enable<br>0: Receive FIFO 1 overflow interrupt disabled<br>1: Receive FIFO 1 overflow interrupt enabled<br><b>Note:</b> The flag bit of this interrupt is the RF1OF bit. An                                         |

|       |         |     |    |                                                                                                                                                                                                                                                                                |
|-------|---------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     |    | interrupt is generated when this bit and RF1OF bit are set.                                                                                                                                                                                                                    |
| Bit 5 | RF1FIEN | 0x0 | rw | <p>Receive FIFO 1 full interrupt enable<br/>0: Receive FIFO 1 full interrupt disabled<br/>1: Receive FIFO 1 full interrupt enabled</p> <p>Note: The flag bit of this interrupt is the RF1FF bit. An interrupt is generated when this bit and RF1FF bit are set.</p>            |
| Bit 4 | RF1MIEN | 0x0 | rw | <p>FIFO 1 receive message interrupt enable<br/>0: FIFO 1 receive message interrupt disabled<br/>1: FIFO 1 receive message interrupt enabled</p> <p>Note: The flag bit of this interrupt is RF1MN bit, so an interrupt is generated when this bit and RF1MN bit are set.</p>    |
| Bit 3 | RF0OIEN | 0x0 | rw | <p>Receive FIFO 0 overflow interrupt enable<br/>0: Receive FIFO 0 overflow interrupt disabled<br/>1: Receive FIFO 0 overflow interrupt enabled</p> <p>Note: The flag bit of this interrupt is RF0OF bit, so an interrupt is generated when this bit and RF0OF bit are set.</p> |
| Bit 2 | RF0FIEN | 0x0 | rw | <p>Receive FIFO 0 full interrupt enable<br/>0: Receive FIFO 0 full interrupt disabled<br/>1: Receive FIFO 0 full interrupt enabled</p> <p>Note: The flag bit of this interrupt is the RF0FF bit. An interrupt is generated when this bit and RF0FF bit are set</p>             |
| Bit 1 | RF0MIEN | 0x0 | rw | <p>FIFO 0 receive message interrupt enable<br/>0: FIFO 0 receive message interrupt disabled<br/>1: FIFO 0 receive message interrupt enabled</p> <p>Note: The flag bit of this interrupt is the RF0MN bit. An interrupt is generated when this bit and RF0MN bit are set</p>    |
| Bit 0 | TCIEN   | 0x0 | rw | <p>Transmit mailbox empty interrupt enable<br/>0: Transmit mailbox empty interrupt disabled<br/>1: Transmit mailbox empty interrupt enabled</p> <p>Note: The flag bit of this interrupt is the TMxTCF bit. An interrupt is generated when this bit and TMxTCF bit are set</p>  |

### 20.7.1.7 CAN error status register (CAN\_ESTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | REC      | 0x00        | ro   | <p>Receive error counter</p> <p>This counter is implemented in accordance with the receive part of the fault confinement mechanism of the CAN protocol.</p>                                                                                                                                                                                                   |
| Bit 23: 16 | TEC      | 0x00        | ro   | <p>Transmit error counter</p> <p>This counter is implemented in accordance with the transmit part of the fault confinement mechanism of the CAN protocol.</p>                                                                                                                                                                                                 |
| Bit 15: 7  | Reserved | 0x00        | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                        |
|            |          |             |      | <p>Error type record</p> <p>000: No error</p> <p>001: Bit stuffing error</p> <p>010: Format error</p> <p>011: Acknowledgement error</p> <p>100: Recessive bit error</p> <p>101: Dominant bit error</p> <p>110: CRC error</p> <p>111: Set by software</p>                                                                                                      |
| Bit 6: 4   | ETR      | 0x0         | rw   | <p>Note:</p> <p>This field is used to indicate the current error type. It is set by hardware according to the error condition detected on the CAN bus. It is cleared by hardware when a message has been transmitted or received successfully. If the error code 7 is not used by hardware, this field can be set by software to monitor the code update.</p> |
| Bit 3      | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                        |
| Bit 2      | BOF      | 0x0         | ro   | <p>Bus-off flag</p> <p>0: Bus-off state is not entered.</p> <p>1: Bus-off state is entered.</p> <p>Note: When the TEC is greater than 255, the bus-off state is entered, and this bit is set by hardware.</p>                                                                                                                                                 |
| Bit 1      | EPF      | 0x0         | ro   | <p>Error passive flag</p> <p>0: Error passive state is not entered</p> <p>1: Error passive state is entered</p> <p>Note: This bit is set by hardware when the current error times has reached the Error passive state limit (Receive Error Counter or Transmit Error Counter &gt;127)</p>                                                                     |
| Bit 0      | EAF      | 0x0         | ro   | <p>Error active flag</p> <p>0: Error active state is not entered</p> <p>1: Error active state is entered</p> <p>Note: This bit is set by hardware when the current error times has reached the Error active state limit (Receive Error Counter or Transmit Error Counter ≥96)</p>                                                                             |

### 20.7.1.8 CAN bit timing register (CAN\_BTMG)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | LOEN     | 0x0         | rw   | <p>Listen-Only mode</p> <p>0: Listen-Only mode disabled</p> <p>1: Listen-Only mode enabled</p>                                                                                                   |
| Bit 30     | LBEN     | 0x0         | rw   | <p>Loop back mode</p> <p>0: Loop back mode disabled</p> <p>1: Loop back mode enabled</p>                                                                                                         |
| Bit 29: 26 | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                           |
| Bit 25: 24 | RSAW     | 0x1         | rw   | <p>Resynchronization width</p> <p>tRSAW = tCAN x (RSAW[1: 0] + 1)</p> <p>Note: This field defines the maximum of time unit that the CAN hardware is allowed to lengthen or shorten in a bit.</p> |
| Bit 23     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                           |
| Bit 22: 20 | BTS2     | 0x2         | rw   | <p>Bit time segment 2</p> <p>tBTS2 = tCAN x (BTS2[2: 0] + 1)</p> <p>Note: This field defines the number of time unit in Bit time</p>                                                             |

|            |          |       |      |                                                                                                                                  |
|------------|----------|-------|------|----------------------------------------------------------------------------------------------------------------------------------|
|            |          |       |      | segment 2.                                                                                                                       |
| Bit 19: 16 | BTS1     | 0x3   | rw   | Bit time segment 1<br>tBTS1 = tCAN x (BTS1[3: 0] + 1)<br>Note: This field defines the number of time unit in Bit time segment 1. |
| Bit 15: 12 | Reserved | 0x0   | resd | Kept at default value.                                                                                                           |
| Bit 11: 0  | BRDIV    | 0x000 | rw   | Baud rate division<br>tq = (BRDIV[11: 0]+1) x tPCLK<br>Note: This field defines the length of a time unit (tq).                  |

## 20.7.2 CAN mailbox registers

This section describes the registers of the transmit and receive mailboxes. Refer to [Section 20.6.5](#) for more information on register map.

Transmit and receive mailboxes are the same except:

- RFFMN field in the CAN\_RFCx register
- A receive mailbox is read-only
- A transmit mailbox can be written only when empty. TM2S=1 in the CAN\_TSTS register indicates that the mailbox is empty.

There are three transmit mailboxes and two receive mailboxes. Each receive mailbox has 3-level depth of FIFO, and can only access to the first received message in the FIFO.

Each mailbox contains four registers.

Figure 20-14 Transmit and receive mailboxes



### 20.7.2.1 Transmit mailbox identifier register (CAN\_TMIx) (x=0..2)

Note: 1. This register is write protected when its mailboxes are pending for transmission.

2. This register implements the Transmit Request control (bit 0) — reset value 0.

| Bit        | Name         | Reset value | Type | Description                                                                                                                                                                        |
|------------|--------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 21 | TMSID/ TMEID | 0xFFFF      | rw   | Transmit mailbox standard identifier or extended identifier high bytes<br>Note: This field defines the 11-bit high bytes of the standard identifier or extended identifier.        |
| Bit 20: 3  | TMEID        | 0x0000      | rw   | Transmit mailbox extended identifier<br>Note: This field defines the 18-bit low bytes of the extended identifier.                                                                  |
| Bit 2      | TMIDSEL      | 0x0         | rw   | Transmit mailbox identifier type select<br>0: Standard identifier<br>1: Extended identifier                                                                                        |
| Bit 1      | TMFRSEL      | 0x0         | rw   | Transmit mailbox frame type select<br>0: Data frame<br>1: Remote frame                                                                                                             |
| Bit 0      | TMSR         | 0x0         | rw   | Transmit mailbox send request<br>0: No effect<br>1: Transmit request<br>Note: This bit is cleared by hardware when the transmission has been completed (The mailbox becomes empty) |

### 20.7.2.2 Transmit mailbox data length and time stamp register (CAN\_TMCx) (x=0..2)

All the bits in the register are write protected when the mailbox is not in empty state.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | TMTS     | 0xFFFF      | rw   | Transmit mailbox time stamp<br>Note: This field contains the value of the CAN timer sampled at the SOF transmission.                                                                                                                                                                                                                                        |
| Bit 15: 9  | Reserved | 0xFF        | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                       |
|            |          |             |      | Transmit mailbox time stamp transmit enable<br>0: Time stamp is not sent<br>1: Time stamp is sent<br>Note:<br>This bit is valid only when the time-triggered communication mode is enabled.<br>In the time stamp MTS[15: 0], the MTS[7: 0] is stored in the TMDT7, and MTS[15: 8] in the TMDT6. The data length must be programmed as 8 to send time stamp. |
| Bit 7: 4   | Reserved | 0xF         | resd | Kept at default value                                                                                                                                                                                                                                                                                                                                       |
| Bit 3: 0   | TMDTBL   | 0x0         | rw   | Transmit mailbox data byte length<br>Note: This field defines the data length of a transmit message. A transmit message can contain from 0 to 8 data bytes.                                                                                                                                                                                                 |

### 20.7.2.3 Transmit mailbox data low register (CAN\_TMDTLx) (x=0..2)

All the bits in the register are write protected when the mailbox is not in empty state.

| Bit        | Name  | Reset value | Type | Description                  |
|------------|-------|-------------|------|------------------------------|
| Bit 31: 24 | TMDT3 | 0xFF        | rw   | Transmit mailbox data byte 3 |
| Bit 23: 16 | TMDT2 | 0xFF        | rw   | Transmit mailbox data byte 2 |
| Bit 15: 8  | TMDT1 | 0xFF        | rw   | Transmit mailbox data byte 1 |
| Bit 7: 0   | TMDT0 | 0xFF        | rw   | Transmit mailbox data byte 0 |

### 20.7.2.4 Transmit mailbox data high register (CAN\_TMDTHx) (x=0..2)

All the bits in the register are write protected when the mailbox is not in empty state.

| Bit        | Name  | Reset value | Type | Description                                                                                                                                                   |
|------------|-------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | TMDT7 | 0xFF        | rw   | Transmit mailbox data byte 7                                                                                                                                  |
|            |       |             |      | Transmit mailbox data byte 6                                                                                                                                  |
| Bit 23: 16 | TMDT6 | 0xFF        | rw   | Note: This field will be replaced with MTS[15: 8] when the time-triggered communication mode is enabled and the corresponding time stamp transmit is enabled. |
| Bit 15: 8  | TMDT5 | 0xFF        | rw   | Transmit mailbox data byte 5                                                                                                                                  |
| Bit 7: 0   | TMDT4 | 0xFF        | rw   | Transmit mailbox data byte 4                                                                                                                                  |

### 20.7.2.5 Receive FIFO mailbox identifier register (CAN\_RFIdx) (x=0..1)

Note: All the receive mailbox registers are read-only.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                               |
|------------|-------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 21 | RFSID/RFEID | 0xFFFF      | ro   | Receive FIFO standard identifier or receive FIFO extended identifier<br>Note: This field defines the 11-bit high bytes of the standard identifier or extended identifier. |
| Bit 20: 3  | RFEID       | 0xFFFF      | ro   | Receive FIFO extended identifier<br>Note: This field defines the 18-bit low bytes of the extended identifier.                                                             |
| Bit 2      | RFIDI       | 0x0         | ro   | Receive FIFO identifier type indication<br>0: Standard identifier<br>1: Extended identifier                                                                               |
| Bit 1      | RFFRI       | 0x0         | ro   | Receive FIFO frame type indication<br>0: Data frame<br>1: Remote frame                                                                                                    |
| Bit 0      | Reserved    | 0x0         | resd | Kept at default value                                                                                                                                                     |

### 20.7.2.6 Receive FIFO mailbox data length and time stamp register (CAN\_RFCx) (x=0..1)

*Note: All the receive mailbox registers are read-only.*

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                             |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | RFTS     | 0xFFFF      | ro   | Receive FIFO time stamp<br>Note: This field contains the value of the CAN timer sampled at the start of a receive frame.                                                                                |
| Bit 15: 8  | RFFMN    | 0xFF        | ro   | Receive FIFO filter match number<br>Note: This field contains the filter number that a message has passed through.                                                                                      |
| Bit 7: 4   | Reserved | 0xF         | resd | Kept at default value                                                                                                                                                                                   |
| Bit 3: 0   | RFDTL    | 0x0         | ro   | Receive FIFO data length<br>Note: This field defines the data length of a receive message. A transmit message can contain from 0 to 8 data bytes. For a remote frame, its data length RFDTI is fixed 0. |

### 20.7.2.7 Receive FIFO mailbox data low register (CAN\_RFDTLx) (x=0..1)

*Note: All the receive mailbox registers are read-only.*

| Bit        | Name  | Reset value | Type | Description              |
|------------|-------|-------------|------|--------------------------|
| Bit 31: 24 | RFDT3 | 0xFF        | ro   | Receive FIFO data byte 3 |
| Bit 23: 16 | RFDT2 | 0xFF        | ro   | Receive FIFO data byte 2 |
| Bit 15: 8  | RFDT1 | 0xFF        | ro   | Receive FIFO data byte 1 |
| Bit 7: 0   | RFDT0 | 0xFF        | ro   | Receive FIFO data byte 0 |

### 20.7.2.8 Receive FIFO mailbox data high register (CAN\_RFDTIx) (x=0..1)

*Note: All the receive mailbox registers are read-only.*

| Bit        | Name  | Reset value | Type | Description              |
|------------|-------|-------------|------|--------------------------|
| Bit 31: 24 | RFDT7 | 0xFF        | ro   | Receive FIFO data byte 7 |
| Bit 23: 16 | RFDT6 | 0xFF        | ro   | Receive FIFO data byte 6 |
| Bit 15: 8  | RFDT5 | 0xFF        | ro   | Receive FIFO data byte 5 |
| Bit 7: 0   | RFDT4 | 0xFF        | ro   | Receive FIFO data byte 4 |

## 20.7.3 CAN filter registers

### 20.7.3.1 CAN filter control register (CAN\_FCTRL)

*Note: All the non-reserved bits of this register are controlled by software completely.*

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                     |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x150E0700  | resd | Kept at its default value                                                                                                                                                                                                       |
| Bit 0     | FCS      | 0x1         | rw   | Filter configuration switch<br>0: Disabled (Filter bank is active)<br>1: Enabled (Filter bank is in configuration mode)<br>Note: The initialization of the filter bank can be configured only when it is in configuration mode. |

### 20.7.3.2 CAN filter mode configuration register (CAN\_FMCFG)

*Note: This register can be written only when FCS=1 in the CAN\_FCTRL register (The filter is in configuration mode).*

| Bit        | Name     | Reset value | Type | Description                                                                                                        |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x000000    | resd | Kept at default value                                                                                              |
| Bit 13: 0  | FMSELx   | 0x0000      | rw   | Filter mode select<br>Each bit corresponds to a filter bank.<br>0: Identifier mask mode<br>1: Identifier list mode |

### 20.7.3.3 CAN filter bit width configuration register (CAN\_FBWCFG)

*Note: This register can be written only when FCS=1 in the CAN\_FCTRL register (The filter is in configuration mode).*

| Bit        | Name     | Reset value | Type | Description                                                                                             |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x00000     | resd | Kept at default value                                                                                   |
| Bit 13: 0  | FBWSELx  | 0x0000      | rw   | Filter bit width select<br>Each bit corresponds to a filter bank.<br>0: Dual 16-bit<br>1: Single 32-bit |

### 20.7.3.4 CAN filter FIFO association register (CAN\_FRF)

*Note: This register can be written only when FCS=1 in the CAN\_FCTRL register (The filter is in configuration mode).*

| Bit        | Name     | Reset value | Type | Description                                                                                                                   |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x00000     | resd | Kept at default value                                                                                                         |
| Bit 13: 0  | FRFSELx  | 0x0000      | rw   | Filter relation FIFO select<br>Each bit corresponds to a filter bank.<br>0: Associated with FIFO0<br>1: Associated with FIFO1 |

### 20.7.3.5 CAN filter activation control register (CAN\_FACFG)

| Bit        | Name     | Reset value | Type | Description                                                                                 |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x00000     | resd | Kept at default value                                                                       |
| Bit 13: 0  | FAENx    | 0x0000      | rw   | Filter active enable<br>Each bit corresponds to a filter bank.<br>0: Disabled<br>1: Enabled |

### 20.7.3.6 CAN filter bank i filter bit register (CAN\_FiFBx) (i=0..13; x=1..2)

*Note: There are 14 filter banks (i=0..13). Each filter bank consists of two 32-bit registers, CAN\_FiFB[2:1]. This register can be modified only when the FAENx bit of the CAN\_FACFG register is cleared or the FCS bit of the CAN\_FCTRL register is set.*

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | FFDB | 0x0000 0000 | rw   | Filters filter data bit<br>Identifier list mode:<br>The configuration value of the register matches with the level of the corresponding bit of the data received on the bus (If it is a standard frame, the value of the corresponding bit of the extended frame is neglected.)<br>Identifier mark mode:<br>Only the bit with its register configuration value being 1 can match with the level of the corresponding bit of the data received on the bus. It don't care when the register value is 0. |

# 21 USB full-speed/high-speed device interface (OTGFS/HS)

The AT32F405 series supports OTGFS/OTGHS mode, and the AT32F402 series supports OTGFS mode only.

As a dual-role device, the OTGFS/OTGHS is fully compliant with the Universal Serial Bus Specification Revision 2.0.

## 21.1 OTGFS/OTGHS structure

Figure 21-1 OTGFS block diagram



Figure 21-2 OTGHS block diagram



## 21.2 OTGFS/HS functional description

For OTGFS controller, in host mode, it supports full speed (12Mb/s) and low speed (1.5 Mb/s); In device mode, it supports only full speed (12Mb/s).

For OTGHS controller, in host mode, it supports high speed (480Mb/s), full speed (12Mb/s) and low speed (1.5 Mb/s); in device mode, it supports high speed (480Mb/s) and full speed (12Mb/s).

OTGFS module consists of an OTGFS controller, on-chip 2.0 FS PHY and a dedicated 1280-byte SRAM.

OTGHS module consists of an OTGHS controller, on-chip 2.0 HS PHY and a dedicated 4096-byte SRAM.

OTGHS embeds an internal DMA controller which accesses other peripherals as a host of AHB bus matrix.

OTGFS/HS supports control transfer, bulk transfer, interrupt transfer and isochronous transfer.

The OTGFS/HS is a USB dual-role device controller that supports both device and host functions, depending on the level of the ID line. When the ID line is in a floating state, the OTGFS/HS runs in device mode. When the ID line is grounded, the OTGFS/HS host role is confirmed. The OTG PHY embeds an 1.5KΩ of pull-up resistor and 15KΩ of pull-down resistor for this OTGFS/HS dual-role controller.

In device mode, the OTGFS/HS supports one bidirectional control endpoint, 7 IN endpoints, and 7 OUT endpoints; in host mode, the OTGFS/HS supports 16 host channels.

The OTGFS/HS supports SOF pulse and OE pulse functions: a SOF pulse is generated at any SOF starting token. The SOF pulse can be output to device pins and timer 2. An OE pulse is generated together with data output. The OE pulse can be output to device pins.

In device mode, the OTGFS/HS offers a unified FIFO buffer for all OUT endpoints, and a separate FIFO buffer for each of IN endpoints. In host mode, a unified receive FIFO is arranged for periodic and non-

periodic transfers of all IN endpoints, as well as a unified transmit FIFO for non-periodic transfers of all OUT endpoints.

Suspend mode is supported. In this case, the OTGFS/HS goes into power-saving mode. Besides, it is also possible to achieve low power consumption by setting the PWRDOWN bit in the OTGFS/HS\_GCCFG register, or STOPPCLK bit in the OTGFS/HS\_PCGCCTL register.

## 21.3 OTGFS/HS clock and pin configuration

### 21.3.1 OTGFS clock configuration

The OTGFS has two clock sources, one is  $48MHz \pm 0.25\%$  clock for OTGFS controller, and the other AHB bus clock for accessing OTGFS control register.

OTGFS 48M has the following two clock sources:

- **HICK 48M**

When the HICK 48M clock is selected as an USB clock, enabling ACC feature is recommended.

- **PLL**

The PLL is configured as 48 MHz clock output (see the CRM\_PLLCFG register)

*Note: The AHB clock frequency must be higher than 30 MHz when using OTGFS.*

### 21.3.2 OTGHS clock configuration

The device offers a 12MHz ( $\pm 50ppm$ ) clock to OTGHS PHY and an AHB bus clock to OTGHS controller. The OTGHS PHY also offers a UTMI clock to OTGHS controller for communication purposes between them.

OTGHS 12M clock source:

- 12M clock required for OTGHS PHY is provided by HEXT.

*Note:*

1. *The APB clock frequency must be higher than 30MHz when OTGHS is enabled.*
2. *PWRDOWN feature is allowed to be enabled only after the stabilization of OTGHS PHY 12MHz clock.*

*After the PWRDOWN is enabled, it is necessary to wait for 1ms stabilization time before continuing operation.*

### 21.3.3 OTGFS/HS pin configuration

The OTGFS/HS input/output pins are shared with GPIOs. The GPIOs are used as OTGFS/HS in one of the following conditions:

Table 21-1 OTGFS input/output pins

| Pin        | GPIO | Description                                                                                                      |
|------------|------|------------------------------------------------------------------------------------------------------------------|
| OTGFS_SOF  | PA8  | Enable OTGFS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PA8 as multiplexed function mode  |
| OTGFS_VBUS | PA9  | Enable OTGFS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PA9 as multiplexed function mode  |
| OTGFS_ID   | PA10 | Enable OTGFS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PA10 as multiplexed function mode |
| OTGFS_D-   | PA11 | Enable OTGFS module in CRM, and PWRDOWN=1                                                                        |
| OTGFS_D+   | PA12 | Enable OTGFS module in CRM, and PWRDOWN=1                                                                        |
| OTGFS_OE   | PA13 | Enable OTGFS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PA13 as multiplexed function mode |

Table 21-2 OTGHS input/output pins

| Pin        | GPIO | Description                                                                                                      |
|------------|------|------------------------------------------------------------------------------------------------------------------|
| OTGHS_SOF  | PA4  | Enable OTGHS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PA4 as multiplexed function mode  |
| OTGHS_VBUS | PB13 | Enable OTGHS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PB13 as multiplexed function mode |
| OTGHS_ID   | PB12 | Enable OTGHS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PB12 as multiplexed function mode |
| OTGHS_D-   | -    | Dedicated OTGHS pin                                                                                              |
| OTGHS_D+   | -    | Dedicated OTGHS pin                                                                                              |
| OTGHS_R    | -    | Dedicated OTGHS pin                                                                                              |
| OTGHS_OE   | PC9  | Enable OTGHS module in CRM, and set GPIOx_MUXH register as 0xa, and configured PC9 as multiplexed function mode  |

## 21.4 OTGFS/HS interrupts

Figure 21-3 shows the OTGFS/HS interrupt hierarchy. Refer to the OTGFS/HS interrupt register (OTGFS/HS\_GINTSTS) and OTGFS/HS interrupt mask register (OTGFS/HS\_GINTMSK).

Figure 21-3 OTGFS/HS interrupt hierarchy



## 21.5 OTGFS/HS functional description

### 21.5.1 OTGFS/HS initialization

If the cable is connected during power-on, the current operation mode bit (CURMOD bit) in the controller interrupt register indicates the current operation mode. If an “A” plug is connected, the OTGFS/HS controller enters host mode; when a “B” plug is connected, the OTGFS/HS controller enters device mode.

This section describes how to initialize the OTGFS /HS controller after power-on. The application must follow the initialization sequence, whatever mode (in host or device mode). All controller global registers are initialized according to the controller configuration.

**1. Configure the following fields in the AHB global configuration register:**

- Global interrupt mask bit = 0x1
- Non-periodic transmit FIFO empty level
- Periodic transmit FIFO empty level

**2. Configure the following fields in the global interrupt mask register:**

- OTGFS/HS\_GINTMSK.RXFLVLMSK = 0x0

**3. Configure the following fields in the OTGFS/HS\_GUSBCFG register:**

- Full-speed timeout standard bit
- USB turnaround time bit

**4. The software must unmask the following bits in the OTGFS/HS\_GINTMSK register:**

- OTG interrupt mask
- Mode mismatch interrupt mask

5. The software reads the CURMOD bit in the OTGFS/HS\_GINTSTS register to determine whether the OTGFS/HS controller is in host or device mode.

### 21.5.2 OTGFS/HS FIFO configuration

#### 21.5.2.1 Device mode

A dynamic FIFO allocation is required during power-on or USB reset. In device mode, the application must meet the following conditions before change to FIFO SRAM allocation.

- OTGFS/HS\_DIEPCTLx/OTGFS/HS\_DOEPCTLx.EPENA = 0x0
- OTGFS/HS\_DIEPCTLx/OTGFS/HS\_DOEPCTLx.NAKSTS = 0x1

The TXFNUM bit in the OTGFS\_GRSTCTL register is used to refresh the controller transmit FIFO. Refer to Section Refresh controller transmit FIFO for more information.

Attention should be paid to the following information when it comes to FIFO SRAM allocation:

**(1) Receive FIFO SRAM allocation**

- SRAM for SETUP Packets: 13 WORDs must be reserved in the receive FIFO to receive one SETUP Packet on a control endpoint. The controller does not use these locations which are reserved for SETUP packets.
- One WORD is reserved for global OUT NAK
- Status information is written to the FIFO along with each received packet. Therefore, a minimum space of (largest packet size/4) + 1 must be allocated to receive data packets. If multiple synchronous endpoints are enabled, at least two (largest packet size/4) + 1 must be allocated to receive back-to-back data packets. In most cases, two (largest packet size/4) + 1 spaces are recommended so that the USB can receive the subsequent packet while the previous packet is being transferred to the AHB. If there is a longer latency on AHB, sufficient spaces must be reserved to receive multiple packets in order to prevent synchronous data packet loss.
- Transfer complete status information, along with the last packet on each endpoint, is pushed into the FIFO
- One location must be reserved for the disable status bit of each endpoint
- Typically, two WORDs for each OUT endpoint are recommended.

**(2) Transmit FIFO SRAM allocation**

The minimum SRAM space required for each IN endpoint transmit FIFO is the maximum data packet size for that particular IN endpoint. The greater the space allocated to the transmit IN endpoint FIFO, the better the USB performance, and this helps to avoid latency on the AHB line.

Table 21-3 OTGFS/HS transmit FIFO SRAM allocation

| FIFO name       | SRAM size                                                                                     |
|-----------------|-----------------------------------------------------------------------------------------------|
| Receive FIFO    | rx_fifo_size, including setup packets, OUT endpoint control information and OUT data packets. |
| Transmit FIFO 0 | tx_fifo_size[0]                                                                               |
| Transmit FIFO 1 | tx_fifo_size[1]                                                                               |
| Transmit FIFO 2 | tx_fifo_size[2]                                                                               |
| .....           | .....                                                                                         |
| Transmit FIFO i | tx_fifo_size[i]                                                                               |

Configure the following registers according to the above mentioned:

1. OTGFS/HS receive FIFO size register (OTGFS/HS\_GRXFSIZ)

- OTGFS/HS\_GRXFSIZ.RXFDEP = rx\_fifo\_size

2. Endpoint 0 TX FIFO size register (OTGFS/HS\_DIEPTXF0)

- OTGFS/HS\_DIEPTXF0.INEPT0TXDEP = tx\_fifo\_size[0];

- OTGFS/HS\_DIEPTXF0.INEPT0TXSTADDR = rx\_fifo\_size

3. Device IN endpoint transmit FIFO#1 size register (OTGFS/HS\_DIEPTXF1)

- OTGFS/HS\_DIEPTXF1.INEPTXFSTADDR = OTGFS/HS\_GNPTXFSIZ.NPTXFSTADDR + tx\_fifo\_size[0]

4. Device IN endpoint transmit FIFO#2 size register (OTGFS/HS\_DIEPTXF2)

- OTGFS/HS\_DIEPTXF2.INEPTXFSTADDR = OTGFS/HS\_DIEPTXF1.INEPTXFSTADDR + tx\_fifo\_size[1]

5. Device IN endpoint transmit FIFO#i size register (OTGFS/HS\_DIEPTXF*i*)

- OTGFS/HS\_DIEPTXF*i*.INEPTXFSTADDR = OTGFS/HS\_DIEPTXF*i*-1.INEPTXFSTADDR + tx\_fifo\_size[i-1]

6. After SRAM allocation, refresh transmit FIFO and receive FIFO to ensure normal FIFO running.

- OTGFS/HS\_GRSTCTL.TXFNUM = 0x10

- OTGFS/HS\_GRSTCTL.TXFFLSH = 0x1

- OTGFS/HS\_GRSTCTL.RXFFLSH = 0x1

The application cannot perform operations on the controller until the TXFFLSH and RXFFLSH bits are cleared.

## 21.5.2.2 Host mode

In host mode, the application must confirm the following status before changing FIFO SRAM allocation:

- All channels have been disabled
- All FIFOs are empty

After FIFO SRAM allocation is complete, the application must refresh all FIFOs in the controller through the TXFNUM bit in the OTGFS/HS\_GRSTCTL register.

After allocation, the FIFO pointer must be reset by refreshing operation to ensure normal FIFO run. Refer to Section Refresh controller transmit FIFO for more information.

### (1) Receive FIFO SRAM allocation

Status information is written to the FIFO along with each received packet. Therefore, a minimum space of (largest packet size/4) + 2 must be allocated to receive data packets. If more synchronous endpoints are enabled, then at least two (largest packet size/4) + 2 spaces must be allocated to receive back-to-back packets. In most cases, two (largest packet size/4) + 2 spaces are recommended so that the USB can receive the subsequent packet while the previous packet is being transferred to the AHB. If there is a longer latency on AHB, sufficient spaces must be reserved to receive multiple packets in order to prevent synchronous data packet loss.

Transfer complete status information and channel abort information, along with the last packet in the host channel is also pushed to the FIFO. Thus, two DWORDs must be allocated for this.

### (2) Transmit FIFO SRAM allocation

The minimum SRAM space required for the host non-periodic transmit FIFO is the largest packet size of all non-periodic OUT channels. The more the space allocated to the non-periodic FIFO, the better the

USB performance, and this helps to avoid latency on the AHB line. Typically, two largest packet sizes of space is recommended so that the AHB can get the next data packet while the current packet is being transferred to the USB. If there is a longer latency on AHB, sufficient spaces must be reserved to receive multiple packets in order to prevent synchronous data packet loss.

The minimum number of SRAM space required for the host periodic transmit FIFO is the largest packet size of all periodic OUT channels.

### (3) Internal storage space allocation

Table 21-4 OTGFS/HS internal memory storage space allocation

| FIFO Name                  | Data SRAM Size  |
|----------------------------|-----------------|
| Receive FIFO               | rx_fifo_size    |
| Non-periodic transmit FIFO | tx_fifo_size[0] |
| Periodic transmit FIFO     | tx_fifo_size[1] |

Configure the following registers according to the above mentioned:

1. OTGFS/HS receive FIFO size register (OTGFS/HS\_GRXFSIZ)
  - OTGFS/HS\_GRXFSIZ.RXFDEP = rx\_fifo\_size
2. OTGFS/HS Non-periodic TX FIFO size register (OTGFS/HS\_GNPTXFSIZ)
  - OTGFS/HS\_GNPTXFSIZ.NPTXFDEP = tx\_fifo\_size[0]
  - OTGFS/HS\_GNPTXFSIZ.NPTXFSTADDR = rx\_fifo\_size
3. OTGFS/HS host periodic transmit FIFO size register (OTGFS/HS\_HPTXFSIZ)
  - OTGFS/HS\_HPTXFSIZ.PTXFSIZE = tx\_fifo\_size[1]
  - OTGFS/HS\_HPTXFSIZ.PTXFSTADDR = OTGFS/HS\_GNPTXFSIZ.NPTXFSTADDR + tx\_fifo\_size[0]
4. After SRAM allocation, refresh transmit FIFO and receive FIFO to ensure normal FIFO running.
  - OTGFS/HS\_GRSTCTL.TXFNUM = 0x10
  - OTGFS/HS\_GRSTCTL.TXFFLSH = 0x1
  - OTGFS/HS\_GRSTCTL.RXFFLSH = 0x1
  - The application cannot perform other operations on the controller until the TXFFLSH and RXFFLSH bits are cleared.

#### 21.5.2.3 Refresh controller transmit FIFO

The application refreshes all transmit FIFOs through the TXFFLSH bit in the OTGFS/HS\_GRSTCTL register:

- Check whether GINNAKEFF=0 or not in the OTGFS/HS\_GINTSTS register. If this bit has been cleared, write 0x1 to the SGNPINNAK in the OTGFS/HS\_DCTL register. When the NACK valid interrupt is set, it indicates that the controller does not read FIFO.
- Wait until GINNAKEFF = 0x1 in the OTGFS/HS\_GINTSTS register, indicating that the NAK configuration has taken effect for all IN endpoints.
- Poll the OTGFS/HS\_GRSTCTL register and wait until AHVIDLE=1. AHVIDLE = H indicates that the controller does not write the FIFO.
- Confirm whether TXFFLSH = 0x0 or not in the OTGFS/HS\_GRSTCTL register. If TXFFLSH is cleared, write the transmit FIFO number to be refreshed into the OTGFS/HS\_GRSTCTL.TXFNUM register.
- Set TXFFLSH = 0x1 in the OTGFS/HS\_GRSTCTL register, and wait until it is cleared.
- Set the CGNPINNAK bit in the OTGFS/HS\_DCTL register.

#### 21.5.3 OTGFS /HS host mode

In OTGFS/HS host mode, on-chip 5V VBUS generation is not supported. As a result, a charger pump must be added externally to drive the 5V VBUS power line.

### 21.5.3.1 Host initialization

The following steps must be respected to initialize the controller:

1. Unmask interrupt through the PRTINTMSK bit in the OTGFS/HS\_GINTMSK register
2. Program the OTGFS/HS\_HCFG register to select full-speed or high-speed host mode
3. Set PRTPWR = 0x1 in the OTGFS/HS\_HPRT register to drive VBUS on the USB
4. Wait until that the PRTCNDDETbit is set in the OTGFS/HS\_HPRT0 register, indicating that the device is connected to the port
5. Set PRTRST = 0x1 in the OTGFS/HS\_HPRT register to issue a reset operation
6. Wait for at least 10 ms to ensure the completion of the reset
7. Set PRTRST = 0x0 in the OTGFS/HS\_HPRT register
8. Wait for the interrupt (PRTENCHNG bit in the OTGFS/HS\_HPRT register)
9. Read the PRTSPD bit in the OTGFS/HS\_HPRT register to get the enumeration speed
10. Configure the HFIR register according to the selected PHY clock value
11. Select the size of the receive FIFO by setting the OTGFS/HS\_GRXFSIZ register
12. Select the start address and size of the non-periodic transmit FIFO by setting the OTGFS/HS\_GNPTXFSIZ register
13. Select the start address and size of the periodic transmit FIFO by setting the OTGFS/HS\_HPTXFSIZ register

To communicate with the device, the application must enable and initialize at least one channel according to OTGFS/HS channel initialization requirements.

### 21.5.3.2 OTGFS/HS channel initialization

To communicate with the device, the application must enable and initialize at least one channel according to the following steps:

1. Unmask the following interrupts by setting the OTGFS/HS\_GINTMSK register:
  - Non-periodic transmit FIFO empty for OUT transfers
  - Non-periodic transmit FIFO half empty for OUT transfers
2. Unmask the interrupts of the selected channels by setting the OTGFS/HS\_HAINTMSK register
3. Unmask the transfer-related interrupts in the host channel interrupt register by setting the OTGFS/HS\_HCINTMSKx register
4. Configure the total transfer size (in bytes), and the expected number of the packets (including short packets) for the OTGFS/HS\_HCTSIZx register of the selected channel. The application must configure the PID bit according to the initial data PID (it is the PID on the first OUT transfer, or to be received from the first IN transfer)
5. Configure the transfer size to ensure that the transfer size of the channel is a multiple of the largest packet size
6. Configure the OTGFS/HS\_HCCHARx register of the selected channel according to the device endpoint characteristics such as type, speed and direction (the channel cannot be enabled by setting the enable bit until the application is ready for packet transfer or reception)

### 21.5.3.3 Halting a channel

The application can disable a channel by writing 0x1 to the CHDIS and CHENA bits in the OTGFS/HS\_HCCHARx register. This enables the host to refresh the submitted requests (if any) and generates a channel halted interrupt. The application cannot re-allocate channels for other transactions until an interrupt is generated in the OTGFS/HS\_HCINTx register (CHHLTD bit). Those transactions that have already been started on the USB line are not interrupted by the host.

Before disabling a channel, the application must ensure that there is at least one free space available in the non-periodic request queue (when disabling a non-periodic channel) or the periodic request queue (when disabling a periodic channel). The application can refresh the submitted requests when the request queue is full (before disabling the channel) by setting CHDIS=0x1, and CHENA=0 in the OTGFS\_HCCHARx register.

When there is a transaction input in the request queue, the controller will trigger a RXFLVL interrupt. The application must generate a channel halted interrupt through the OTGFS/HS\_GRXSTSP register.

The application is expected to abort a channel on any of the following conditions:

- When an interrupt (XFERC bit) is received in the OTGFS/HS\_HCINTx register during a non-periodic IN transfer
- When an STALL , XACTERR , BBLERR or DTGLERR interrupt in the OTGFS/HS\_HCINTx register is received for an IN or OUT channel
- When a DISCONINT (device disconnected) interrupt event is received in the OTGFS/HS\_GINTSTS register, the application must check the PRTCONSTS bit in the OTGFS/HS\_HPRT register. This is because when the device is disconnected with the host, the PRTCONSTS bit will be reset in the OTGFS/HS\_HPRT register. The application must initiate a software reset to ensure that all channels have been cleared. Once the device is reconnected, the host must start a USB reset.
- When the application needs to abort a transfer before normal completion

#### 21.5.3.4 Queue depth

Up to 8 interrupt and isochronous transfer requests are supported in the periodic hardware transfer request queue; while up to 8 control and bulk transfer requests are allowed in the non-periodic hardware transfer request queue.

##### ● Writing the transmit FIFO

*Figure 21-4* shows the flow chart of writing the transmit FIFO. The OTGFS host automatically writes an entry (OUT request) to the periodic/non-periodic request queue when writing the last one WORD packet. The application must ensure that at least one free space is available in the periodic/non-periodic request queue before starting to write to the transmit FIFO. The application must always write to the transmit FIFO in WORDs. If the packet size is not aligned with WORD, the application must use padding. The OTGFS/HS host determines the actual packet size according to the programmed maximum packet size and transfer size.

Figure 21-4 Writing the transmit FIFO



- **Reading the receive FIFO**

*Figure 21-5* shows the flow chart of reading the receive FIFO. The application must ignore all packet statuses other than IN data packet (0x0010).

Figure 21-5 Reading the receive FIFO



### 21.5.3.5 Special cases

#### (1) Handling babble conditions

The OTGFS/HS controller handles two cases of babble: packet babble and port babble. Packet babble occurs if the device sends more than the largest packet size for the channel. Port babble occurs if the controller continues to receive data from the device at EOF2 (the end of frame 2, which is very close to SOF).

When the OTGFS/HS controller detects a packet babble, it stops writing data to the receiver buffer and waits for the completion of packet. When it detects the end of packet, the OTGFS/HS flushes the data already written in the receiver buffer and generates a babble interrupt.

When the OTGFS/HS controller detects a port babble, it flushes the receive FIFO and disables the port. Then the controller generates a Port disable interrupt. Once receiving the interrupt, the application must determine that this is not caused by an overcurrent condition (another cause of the port disable interrupt) by checking the PTOVRCACT bit in the OTGFS/HS\_HPRT register, then perform a software reset. The controller does not send any more tokens if a port babble signal is detected.

#### (2) Handling device disconnected conditions

If the device is suddenly disconnected, an interrupt is generated on a disconnect event (DISCONINT bit in the OTGFS/HS\_GINTSTS register). Upon receiving this interrupt, the application must start a software reset through the CSFTRST in the OTGFS/HS\_GRSTCTL register.

### 21.5.3.6 Host HFIR feature

The host frame interval register (HFIR) defines the interval between two consecutive SOFs (full-speed), micor-SOFs (HS) or Keep-Alive tokens. This field contains the number of PHY clock for the required frame interval. This is mainly used to adjust the SOF duration in accordance with PHY clock frequencies.

[Figure 21-6](#) shows the HFIR behavior when the HFIRRLDCTRL is set to 0x0 in the OTGFS/HS\_HFIR register.

Figure 21-6 HFIR behavior when HFIRRLDCTRL=0x0



Follow the operation sequence below:

1. After power-on reset, the current HFIR value set by the application is shown
2. The application loads a new value into the HFIR register
3. As the HFIR downcounter is reloaded, it will immediately restart counting and cause SOF synchronization lost
4. Restart HFIR counter
5. HFIR register receives a new programmed value
6. Obtain SOF re-synchronization after the first SOF is generated using the HFIR new feature

[Figure 21-7](#) shows the HFIR behavior when HFIRRLDCTRL=0x1 in the OTGFS/HS\_HFIR register.

Figure 21-7 HFIR behavior when HFIRRLDCTRL=0x1



Follow the operation sequence of operation below:

1. After power-on reset, the current HFIR value set by the application is shown
2. The application loads a new HFIR value; the HFIR counter does not apply this new value, but continues counting until it reaches 0
3. The counter generates a SOF when it reaches 0 using the old HFIR value
4. The HFIR counter applies a new value
5. New HFIR value takes effect

The SOF synchronization resumes after going through above-mentioned steps.

### 21.5.3.7 Initialize bulk and control IN transfers

*Figure 21-8* shows a typical bulk or control IN transfer operation. Refer to channel 2 (ch\_2) for more information. The assumptions are as follows:

- The application is attempting to receive two largest-packet-size packets (transfer size is 1024 bytes)
- The receive FIFO contains at least one largest-packet-size packet and two status WORDs per each packet (72 bytes for full-speed transfer)
- The non-periodic request queue depth is 4

#### (1) Operation process for common bulk and control IN transfers

The operation sequence shown in *Figure 21-8* include:

1. Initialize channel 2 (according to OTGFS/HS channel initialization requirements)
2. Set the CHENA bit in the OTGFS/HS\_HCCHAR2 register to write an IN request to the non-periodic request queue
3. The controller issues an IN token after completing the current OUT transfer
4. The controller generates a RXFLVL interrupt once the receive packet is written into the receive FIFO
5. To handle the RXFLVL interrupt, mask the RXFLVL interrupt and read the received packet status to determine the number of bytes received, and then read the receive FIFO. Following this step to unmask the RXFLVL interrupt
6. The controller generates the RXFLVL interrupt when the transfer complete status is written into the receive FIFO

7. The application must read the receive packet status, and ignore it when the receive packet status is not an IN data packet
8. The controller generates the XFERC interrupt as soon as the receive packet is read
9. To handle the XFERC interrupt, disable the channel (see Halting a channel) and stop writing the OTGFS/HS\_HCCHAR2 register. The controller writes a channel halted request to the non-periodic request queue once the OTGFS/HS\_HCCHAR2 register is written
10. The controller generates the RXFLVL interrupt once the halt status is written to the receive FIFO
11. Read and ignore the receive packet status
12. The controller generates a CHHLTD interrupt once the halt status is read from the receive FIFO
13. In response to the CHHLTD interrupt, the processor does not allocate the channel for other transfers.

## (2) Handling interrupts

The following code describes the interrupt service routine related to the channel during bulk and control IN transfers

```
Unmask (XACTERR/XFERC/BBLERR/STALL/DATATGLERR)
if (XFERC)
{
    Reset Error Count
    Unmask CHHLTD
    Disable Channel
    Reset Error Count
    Mask ACK
}
else if (XACTERR or BBLERR or STALL)
{
    Unmask CHHLTD
    Disable Channel
    if (XACTERR)
    {
        Increment Error Count
        Unmask ACK
    }
}
else if (ChHltd)
{
    Mask CHHLTD
    if (Transfer Done or (Error_count == 3))
    {
        De-allocate Channel
    }
    else
    {
        Re-initialize Channel
    }
}
else if (ACK)
{
    Reset Error Count
    Mask ACK
}
else if (DATATGLERR)
```

```
{  
    Reset Error Count  
}
```

### 21.5.3.8 Initialize bulk and control OUT/SETUP transfers

*Figure 21-8* shows a typical bulk or control transfer OUT/SETUP transfer operation. Refer to channel 1 (ch\_1) for more information. It is necessary to send two bulk transfer OUT packets. The control transfer SETUP operation is the same, just the fact that it has only one packet. The assumptions are as follows:

- The application is attempting to send two largest-packet-size packets (transfer size is 1024 bytes)
- The non-periodic transmit FIFO can store two packets (128 bytes for full-speed transfer)
- The non-periodic request queue depth is 4

#### (1) OUT/SETUP operation process for common bulk and control transfer

The operation sequence shown in *Figure 21-8* include:

1. Initialize channel 1 (according to OTGFS/HS channel initialization requirements)
2. Write the first packet for channel 1
3. Along with the last WORD write, the controller writes a request to the non-periodic request queue
4. The controller sends an OUT token in the current frame once the non-periodic queue becomes empty
5. Write the second packet (the last one) to the channel 1
6. The controller generate an XFERC interrupt as soon as the previous transfer is completed successfully
7. In response to the XFERC interrupt, the processor does not allocate the channel for other transfers.

Figure 21-8 Example of common Bulk/Control OUT/SETUP and Bulk/Control IN transfer



## (2) Handling interrupts

The following code describes the interrupt service routine related to the channel during bulk and control transfer OUT/SETUP operation.

```

Unmask (NAK/XACTERR/NYET/STALL/XFERC)
if (XFERC)
{
    {
        Reset Error Count
        Mask ACK
        De-allocate Channel
    }
}
else if (STALL)
{
    Transfer Done = 1
    Unmask CHHLTD
    Disable Channel
}
else if (NAK or XACTERR or NYET)
{
    Rewind Buffer Pointers
}

```

```
Unmask CHHLTD
Disable Channel
if (XactErr)
{
    Increment Error Count
    Unmask ACK
}
else
{
    Reset Error Count
}
}

else if (CHHLTD)
{
    Mask CHHLTD
    if (Transfer Done or (Error_count == 3))
    {
        De-allocate Channel
    }
    else
    {
        Re-initialize Channel (Do ping protocol for HS)
    }
}
else if (ACK)
{
    Reset Error Count
    Mask ACK
}
```

#### Notes:

- The application can only write the transmit FIFO when the transmit FIFO and request queue has free space. The application must check whether there is a free space in the transmit FIFO through the NPTXFEMP bit in the OTGFS/HS\_GINTSTS register
- The application can only write requests when the request queue has free spaces, and continue until an XFERC interrupt is received

### 21.5.3.9 Initialize interrupt IN transfers

*Figure 21-9* shows the operation process of a typical interrupt IN transfer. Refer to channel 2 (ch\_2). The assumptions are as follows:

- The application is attempting to receive one largest-packet-size packet (transfer size is 1024 bytes) from an odd frame
- The receive FIFO can store at least one largest-packet-size packet and two status WORDs per packet (1031 bytes for full-speed transfer)
- The periodic request queue depth is 4

#### (1) Common interrupt IN operation process

The operation sequence shown in Figure 21-9 (channel 2) is as follows:

1. Initialize channel 2 (according to “OTGFS/HS channel initialization” requirements). The application must set the ODDFRM bit in the OTGFS/HS\_HCCHAR2 register
2. Set the CHENA bit in the OTGFS/HS\_HCCHAR2 register to write an IN request to the periodic request queue
3. The OTGFS/HS host writes an IN request to the periodic request queue each time the CHENA is set in the OTGFS/HS\_HCCHAR2 register

4. The OTGFS/HS host attempts to send an IN token in the next frame (odd)
5. The OTGFS/HS host generates a RXFLVL interrupt as soon as an IN packet is received and written to the receive FIFO
6. To handle the RXFLVL interrupt, read the received packet status to determine the number of bytes received, then read the receive FIFO. The application must mask the RXFLVL interrupt before reading the receive FIFO, and unmask the interrupt after reading the entire packet
7. The controller generates the RXFLVL interrupt when the transfer complete status is written to the receive FIFO. The application must read and ignore the receive packet when the receive packet is not an IN packet
8. The controller generates an XFERC interrupt as soon as the receive packet is read
9. To handle the XFERC interrupt, read the PKTCNT bit in the OTGFS/HS\_HCTSIZ2 register. If the PKTCNT bit in the OTGFS/HS\_HCTSIZ2 is not equal to 0, disable the channel before re-initializing the channel for the next transfer. If PKTCNT = 0 in the OTGFS/HS\_HCTSIZ2 register, re-initialize the channel for the next transfer. In this case, the application must reset the ODDFRM bit in the OTGFS/HS\_HCCHAR2 register.

## (2) Interrupt handling

The following code describes the interrupt service routine related to the channel during interrupt IN transfer.

```
Unmask (NAK/XACTERR/XFERC/BBLERR/STALL/FRMOVRUN/DATATGLERR)
if (XFERC)
{
    Reset Error Count
    Mask ACK
    if (HCTSIZx.PKTCNT == 0)
    {
        De-allocate Channel
    }
    else
    {
        Transfer Done = 1
        Unmask CHHLTD
        Disable Channel
    }
}
else if (STALL or FRMOVRUN or NAK or DATATGLERR or BBLERR)
{
    Mask ACK
    Unmask CHHLTD
    Disable Channel
    if (STALL or BBLERR)
    {
        Reset Error Count
        Transfer Done = 1
    }
    else if (!FRMOVRUN)
    {
        Reset Error Count
    }
}
else if (XACTERR)
{
```

```
Increment Error Count
Unmask ACK
Unmask CHHLTD
Disable Channel
}
else if (CHHLTD)
{
Mask CHHLTD
if (Transfer Done or (Error_count == 3))
{
    De-allocate Channel
}
else Re-initialize Channel (in next b_interval - 1 uF/F)
}
}
else if (ACK)
{
Reset Error Count
Mask ACK
}
```

The application can only write requests to the same channel when the remaining space in the request queue reaches the number defined in the MC field, before switching to other channels (if any).

### 21.5.3.10 Initialize interrupt OUT transfers

*Figure 21-9* shows a typical interrupt OUT transfer operation. Refer to channel 1 (ch\_1). The assumptions are as follows:

- The application is attempting to send one largest-packet-size packet (transfer size is 1024 bytes) to every frame
- The periodic transmit FIFO can store one packet (1KB bytes for full-speed transfer)
- The periodic request queue depth is 4

#### (1) Common interrupt IN operation process

The operation sequence shown in Figure 21-8 (channel 1) is as follows:

1. Initialize channel 1 (according to OTGFS/HS channel initialization requirements). The application must set the ODDFRM bit in the OTGFS/HS\_HCCHAR2 register
2. Write the first packet to the channel 1
3. Along with the last WORD write of each packet, the host writes a request to the periodic request queue
4. The host sends an OUT token in the next frame (odd)
5. The host generates an XFERC interrupt after the last packet is transmitted successfully
6. In response to the XFERC interrupt, re-initialize the channel for the next transfer.

#### (2) Interrupt handling

Figure 21-9 shows an example of common interrupt OUT/IN transfers



The following code describes the interrupt service routine related to the channel during interrupt OUT transfers.

```

Unmask (NAK/XACTERR/STALL/XFERC/FRMOVRUN)
if (XFERC)
{
    Reset Error Count
    Mask ACK
    De-allocate Channel
}
else if (STALL or FRMOVRUN)
{
    Mask ACK
    Unmask CHHLTD
    Disable Channel
    if (STALL)
    {
        Transfer Done = 1
    }
}
else if (NAK or XACTERR)
{
    Rewind Buffer Pointers
}

```

```
Reset Error Count
Mask ACK
Unmask CHHLD
Disable Channel
}
else if (CHHLD)
{
Mask CHHLD
if (Transfer Done or (Error_count == 3))
{
De-allocate Channel
}
else
{
Re-initialize Channel (in next b_interval - 1 uF/F)
}
}
else if (ACK)
{
Reset Error Count
Mask ACK
}
```

Before switching to other channels (if any), the application can only write packets to the transmit FIFO and request queue according to the number defined in the MC filed when the transmit FIFO has free spaces. The application can determine whether the transmit FIFO has free spaces through the NPTXFEMP bit in the OTGFS/HS\_GINTSTS register.

### 21.5.3.11 Initialize isochronous IN transfers

*Figure 21-10* shows the operation process of a typical isochronous IN transfer. Refer to channel 2 (ch\_2). The assumptions are as follows:

- The application is attempting to receive one largest-packet-size packet (transfer size is 1024 bytes) from the next odd frame
- The receive FIFO can store at least one largest-packet-size packet and two status WORDs per packet (1031 bytes for full-speed transfer)
- The periodic request queue depth is 4

#### (1) Common isochronous IN transfer

The operation sequence shown in Figure 21-10 (channel 2) is as follows:

1. Initialize channel 2 (according to “OTGFS/HS channel initialization” requirements). The application must set the ODDFRM bit in the OTGFS/HS\_HCCHAR2 register
2. Set the CHENA bit in the OTGFS/HS\_HCCHAR2 register to write an IN request to the periodic request queue
3. The OTGFS host writes an IN request to the periodic request queue each time the CHENA is set in the OTGFS/HS\_HCCHAR2 register
4. The OTGFS/HS host attempts to send an IN token in the next frame (odd)
5. The OTGFS/HS host generates a RXFLVL interrupt as soon as an IN packet is received and written to the receive FIFO
6. To handle the RXFLVL interrupt, read the received packet status to determine the number of bytes received, then read the receive FIFO. The application must mask the RXFLVL interrupt before reading the receive FIFO, and unmask the interrupt after reading the entire packet
7. The controller generates the RXFLVL interrupt when the transfer complete status is written to the receive FIFO. The application must read and ignore the receive packet when the receive packet is

- not an IN packet (GRXSTSR.PKTSTS!= 0x0010)
8. The controller generates an XFERC interrupt as soon as the receive packet is read
  9. To handle the XFERC interrupt, read the PKTCN bit in the OTGFS/HS\_HCTSIZ2 register. If the PKTCNT bit in the OTGFS/HS\_HCTSIZ2 is not equal to 0, disable the channel before re-initializing the channel for the next transfer. If PKTCNT == 0 in the OTGFS/HS\_HCTSIZ2 register, re-initialize the channel for the next transfer. In this case, the application must reset the ODDFRM bit in the OTGFS/HS\_HCCHAR2 register.

## (2) Interrupt handling

The following code describes the interrupt service routine related to the channel during synchronous IN transfers.

```
Unmask (XACTERR/XFERC/FRMOVRUN/BBLERR)
if (XFERC or FRMOVRUN)
{
    if (XFERC and (HCTSIZx.PKTCNT == 0))
    {
        Reset Error Count
        De-allocate Channel
    }
    else
    {
        Unmask CHHLTD
        Disable Channel
    }
}
else if (XACTERR or BBLERR)
{
    Increment Error Count
    Unmask CHHLTD
    Disable Channel
}
else if (CHHLTD)
{
    Mask CHHLTD
    if (Transfer Done or (Error_count == 3))
    {
        De-allocate Channel
    }
    else
    {
        Re-initialize Channel
    }
}
```

### 21.5.3.12 Initialize isochronous OUT transfers

*Figure 21-10* shows a typical isochronous OUT transfer operation. Refer to channel 1 (ch\_1). The assumptions are as follows:

- The application is attempting to send one largest-packet-size packet (transfer size is 1024 bytes) to every frame from the next odd frame
- The periodic transmit FIFO can store one packet (1KB bytes for full-speed transfer)
- The periodic request queue depth is 4

#### (1) Common isochronous OUT transfer

The operation sequence shown in *Figure 21-10* (channel 2) is as follows:

1. Initialize channel 1 (according to OTGFS/HS channel initialization requirements). The application must set the ODDFRM bit in the OTGFS/HS\_HCCHAR1 register
2. Write the first packet to the channel 1
3. Along with the last WORD write of each packet, the host writes a request to the periodic request queue
4. The OTGFS/HS host sends an OUT token in the next frame (odd)
5. The host generates an XFERC interrupt after the last packet is transmitted successfully
6. In response to the XFERC interrupt, re-initialize the channel for the next transfer.

#### (2) Interrupt handling

*Figure 21-10* shows an example of common isochronous OUT transfers

Figure 21-10 Example of common isochronous OUT/IN transfers



The following code describes the interrupt service routine related to the channel during synchronous OUT transfers.

```
Unmask (FRMOVRUN/XFERC)
if (XFERC)
{
    De-allocate Channel
}
else if (FRMOVRUN)
{
    Unmask CHHLD
    Disable Channel
}
else if (CHHLD)
{
    Mask CHHLD
    De-allocate Channel
}
```

## 21.5.4 OTGFS/HS device mode

### 21.5.4.1 Device initialization

The application must perform the following steps to initialize the controller at device startup time, during power-on or after switching from host mode to device mode:

1. Program the following fields in the OTGFS/HS\_DCFG register
  - Device speed
  - Non-zero-length status OUT handshake
  - Periodic frame interval
2. Clear the SFTDISCON bit in the OTGFS/HS\_DCTL register. The controller will start connection after clearing this bit
3. Program the OTGFS/HS\_GINTMSK register to unmask the following interrupts:
  - USB reset
  - Enumeration done
  - Early suspend
  - USB suspend
  - SOF
4. Wait for the USBRESET interrupt in the OTGFS/HS\_GINTSTS register. It indicates that a reset signal has been detected on the USB (lasting for about 10ms). Upon receiving this interrupt, the application must follow the steps defined in USB initialization on USB reset.
5. Wait for the ENUMDONE interrupt in the OTGFS/HS\_GINTSTS register. It indicates the end of USB reset. Upon receiving this interrupt, the application must read the OTGFS/HS\_DSTS register to determine the enumeration speed and perform the steps defined in Endpoint initialization on enumeration completion. At this time, the device is ready to accept SOF packets and perform control transfers on control endpoint 0.

### 21.5.4.2 Endpoint initialization on USB reset

This section describes the operations required for the application to perform when a USB reset signal is detected:

1. Set the NAK bit for all OUT endpoints
  - OTGFS/HS\_DOEPCTLx.SNAK = 0x1(for all OUT endpoints)
2. Unmask the following interrupt bits
  - OTGFS/HS\_DAINTMSK.INEP0 = 0x1(control IN endpoint 0)
  - OTGFS/HS\_DAINTMSK.OUTEP0 = 0x1(control OUT endpoint 0)
  - OTGFS/HS\_DOEPMSK.SETUP = 0x1
  - OTGFS/HS\_DOEPMSK.XFERC = 0x1
  - OTGFS/HS\_DIEPMSK.XFERC = 0x1
  - OTGFS/HS\_DIEPMSK.TIMEOUT = 0x1

3. To receive/transmit data, the device must perform Device initialization steps to initialize registers
  4. Allocate SRAM for each endpoint
    - Program the OTGFS/HS\_GRXFSIZ register to be able to receive control OUT data and SETUP data. If the allocated SRAM is equal to at least 1 largest-packet-size of control endpoint 0 + 2 WORDs (for the status of the control OUT data packet) +10 WORDs (for setup packets)
    - Program the OTGFS/HS\_GNPTXFSIZ register to be able to transmit control IN data. The allocated SRAM is equal to at least 1 largest-packet-size of control endpoint 0
  5. Reset the device address in the device configuration register
  6. Program the following fields in the endpoint-specific registers to ensure that control OUT endpoint 0 is able to receive a SETUP packet
    - OTGFS/HS\_DOEPTSIZ0.SUPCNT = 0x3(to receive up to 3 consecutive SETUP packets)
- At this point, all initialization required to receive SETUP packets is done.

#### 21.5.4.3 Endpoint initialization on enumeration completion

This section describes the operations required for the application to perform when an enumeration completion interrupt signal is detected:

- Upon detecting the enumeration completion interrupt signal, read the OTGFS/HS\_DSTS register to get the enumeration speed
- Program the MPS bit in the OTGFS/HS\_DIEPCTL0 register to set the maximum packet size. This operation is used to configure control endpoint 0. The maximum packet size for a control endpoint depends on the enumeration speed
- Unmask SOF interrupts.

At this point, the device is ready to receive SOF packets and has been configured to perform control transfers on control endpoint 0.

#### 21.5.4.4 Endpoint initialization on SetAddress command

This section describes the operations required for the application to perform when the application receives a SetAddress command in a SETUP packet

- Program the OTGFS/HS\_DCFG register with the device address received in the SetAddress command
- Program the controller to send an IN packet

#### 21.5.4.5 Endpoint initialization on SetConfiguration/SetInterface command

This section describes the operations required for the application to perform when the application receives a SetConfiguration / SetInterface command in a SETUP packet

- When a SetConfiguration command is received, the application must program the endpoint registers according to the characteristics of the valid endpoints defined in the new configuration
- When a SetInterface command is received, the application must program the endpoint registers of the endpoints affected by this command
- Some endpoints that were valid in the previous configuration are not valid in the new configuration. These invalid endpoints must be disabled
- Refer to Endpoint activation and USB endpoint deactivation for more information on how to activate or disable a certain endpoint
- Unmask the interrupt for each valid endpoint and mask the interrupts for all invalid endpoints in the DAINTMSK register
- Refer to OTGFS/HS FIFO configuration for more information on how to program SRAM for each FIFO
- After all required endpoints are configured, the application must program the controller to send a status IN packet
- At this point, the device controller has been ready to receive and transmit any type of data packet.

### 21.5.4.6 Endpoint activation

This section describes how to activate a device endpoint or configure an existing device endpoint to a new type.

1. Program the following bits in the OTGFS/HS\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTGFS/HS\_DOEPCTLx register (for OUT or bidirectional endpoints)

- Largest packet size
- USB valid endpoint = 1
- Endpoint start data toggle (for interrupt and bulk endpoints)
- Endpoint type
- Transmit FIFO number

2. Once the endpoint is activated, the controller starts decoding the tokens issued to this endpoint and sends out a valid handshake for each valid token received for the endpoint

### 21.5.4.7 USB endpoint deactivation

This section describes how to deactivate an existing endpoint. Disable the suspended transfer before performing endpoint deactivation.

- Clear the USB valid endpoint bit in the OTGFS/HS\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTGFS/HS\_DOEPCTLx register (for OUT or bidirectional endpoints)
- Once the endpoint is deactivated, the controller will ignore the tokens issued to this endpoint, which causes a USB timeout.

### 21.5.4.8 Control write transfers (SETUP/Data OUT/Status IN)

This section describes the steps required for control write transfers. The application programming process is as follows:

1. When the SETUP bit is set in the OTGFS/HS\_DOEPINTx register, it indicates that a valid SETUP packet has been sent to the application, and data stage is initiated, see OUT data transfers. At the end of the SETUP stage, the application must rewrite 3 to the SUPCNT bit in the OTGFS/HS\_DOEPTSIx register to receive the subsequent SETUP packet
2. If the last SETUP packet received before the generation of the SETUP interrupt indicates data OUT stage, program the controller to perform OUT transfers according to Asynchronous OUT data transfer operation
3. The application can receive up to 64-byte data for a single OUT data transfer of control endpoint 0. If the application expects to receive more than 64-byte data during data OUT stage, it must re-enable the endpoint to receive another 64-byte data, and it must continue this operation until the completion of all data reception in data stage
4. When the XFERC interrupt is set in the OTGFS/HS\_DOEPINTx register during the last OUT transfer, it indicates the end of data OUT stage of control transfer
5. Once the completion of data OUT stage, the application must perform the following steps:
  - If the application needs to transfer a new SETUP packet, it must re-enable control OUT endpoints (refer to OUT data transfers)  
OTGFS/HS\_DOEPCTLx.EPENA = 0x1
  - To execute the received SETUP commands, the application must configure the corresponding registers in the controller. This is optional, depending on the received SETUP command type
6. During status IN stage, the application must follow the requirements of Non-periodic (for bulk and control) IN data transfers to program registers to perform data IN transfers
7. When the XFERC interrupt is set in the OTGFS/HS\_DOEPINTx register is set, it indicates that the status stage of control transfers is started. As soon as Data transfer complete mode and Status stage start bit are set in the receive FIFO packet status register, the controller generates an interrupt. The Transfer complete interrupt can be cleared through the XFERC bit in the OTGFS/HS\_DOEPINTx register

Repeat above-mentioned steps until an interrupt (XFERC bit in the OTGFS/HS\_DIEPINTx register) is generated on the endpoint, which indicates the end of control write transfers.

### 21.5.4.9 Control read transfers (SETUP/Data IN/Status OUT)

This section describes the steps required for control read transfers.

The application programming process is as follows:

- When the SETUP bit is set in the OTGFS/HS\_DOEPINTx register, it indicates that a valid SETUP packet has been sent to the application, and data stage is initiated, see OUT data transfers. At the end of the SETUP stage, the application must rewrite 3 to the SUPCNT bit in the OTGFS/HS\_DOEPTSI<sub>Z</sub>x register to receive the subsequent SETUP packet
- If the last SETUP packet received before the generation of the SETUP interrupt indicates data IN stage, program the controller to perform IN transfers based on Non-periodic IN data transfer operation
- The application can receive up to 64-byte data for a single IN data transfer of control endpoint 0. If the application expects to receive more than 64-byte data during data IN stage, it must re-enable the endpoint to receive another 64-byte data, and it must continue this operation until the completion of all data transfers in data stage
- Repeat above-mentioned steps until the XFERC interrupt is generated in the OTGFS/HS\_DIEPINTx register for each IN transfer on the endpoint
- When the XFERC interrupt is set in the OTGFS/HS\_DIEPINTx register during the last IN transfer, it indicates the end of data OUT stage of control transfer
- To execute data OUT transfer at status OUT stage, the application must configure the controller. This is optional.

The application must program the NZSTSOUTSHHK bit in the OTGFS/HS\_DCFG register, and then send data OUT transfer at status stage

The XFERC interrupt bit is set in the OTGFS/HS\_DOEPINTx register to indicate the end of status OUT stage of control transfer, marking the completion of control read transfers.

### 21.5.4.10 Control transfers (SETUP/Status IN)

This section describes the two-phase control transfer operation.

The application programming process is as follows:

1. When the SETUP bit is set in the OTGFS/HS\_DOEPINTx register, it indicates that a valid SETUP packet has been sent to the application, and data stage is initiated, see OUT data transfers. At the end of the SETUP stage, the application must re-write 3 to the SUPCNT bit in the OTGFS/HS\_DOEPTSI<sub>Z</sub>x register to receive the subsequent SETUP packet
2. The application decodes the last SETUP packet received before the generation of the SETUP interrupt. If the SETUP packet indicates two-level control commands, the application must perform the following steps:
  - Set OTGFS/HS\_DOEPCTLx.EPENA = 0x1
  - The application must program the registers in the controller to execute the received SETUP commands
3. For status IN stage, the application must program the registers according to “Non-periodic (bulk and control) IN data transfers” to perform data IN transfers
4. The XFERC interrupt bit is set in the OTGFS/HS\_DIEPINTx register to indicate the end of status IN stage of control transfers.

### 21.5.4.11 Read FIFO packets

This section describes how to read FIFO packets (OUT data and SETUP packets)

1. The application must read the OTGFS/HS\_GRXSTSP register as soon as the RXFLVL interrupt bit is detected in the OTGFS/HS\_GINTSTS register
2. The application can mask the RXFLVL interrupt bit in the OTGFS/HS\_GINTSTS register by setting RXFLVL = 0x0 in the OTGFS/HS\_GINTMSK register, until it has read the data packets from the receive FIFO
3. If the received packet byte is not 0, the byte count amount of data is popped from the receive data FIFO and stored in memory. If the received packet byte count is 0, no data is read from the receive

data FIFO

4. The receive FIFO packet status reading indicates one of the following conditions:
5. Global OUT NAK mode: PKTSTS = Global OUT NAK, BCNT = 0x000, EPNUM = Dont Care (0x0) and DPID = Dont Care (0x00), indicating that the global OUT NAK bit has taken effect
- SETUP packet mode: PKTSTS = SETUP, BCnt = 0x008, EPNUM = Control EP Num and DPID = D0, indicating that a SETUP packet for the specified endpoint is now available for reading from the receive FIFO
- Setup stage done mode: PKTSTS = Setup Stage Done, BCNT = 0x0, EPNUM = Control EP Num and DPID = Don't Care (0x00), indicating the completion of the Setup stage for the specified endpoint, and the start of the data stage. After this request is popped from the receive FIFO, the controller triggers a Setup interrupt on the specified control OUT endpoint
- Data OUT packet mode: PKTSTS = DataOUT, BCnt = size of the received data OUT packet ( $0 \leq BCNT \leq 1024$ ), EPNUM = Endpoint number on which the data packet was received, DPID = Actual data PID
- Data transfer complete mode: PKTSTS = Data OUT transfer done, BCNT = 0x0, EPNUM = OUT endpoint number on which the data transfer is complete, DPID = Don't Care (0x00). These data indicate that an OUT data transfer for the specified OUT endpoint has been complete. After this request is popped from the receive FIFO, the controller triggers a Transfer Completed interrupt on the specified OUT endpoint. PKTSTS code can be found in the OTGFS/HS\_GRXSTR / OTGFS/HS\_GRXSTSP register
6. After the valid data is popped from the receive FIFO, the RXFLVL interrupt bit in the OTGFS/HS\_GINTSTS register must be unmasked
7. Step 1-5 must be repeated each time the application detects the interrupt line due to the RXFLVL bit in the OTGFS/HS\_GINTSTS register. Reading an empty receive FIFO will result in unexpected behavior. [Figure 21-11](#) shows a flowchart.

Figure 21-11 Read receive FIFO



### 21.5.4.12 OUT data transfers

This section describes the internal data flow during data OUT and SETUP transfers, and how the application handles SETUP transfers.

#### (1) Setup transfers

This section describes how to handle SETUP data packets and the application's operating sequence of handling SETUP transfers. After power-on reset, the application must follow the OTGFS/HS Initialization process to initialize the controller. Before communicating with the host, the application must initialize the endpoints based on Device Initialization, and refer to Read FIFO packets for more information.

#### 【Application requirements】

1. To receive a SETUP packet, the SUPCNT bit (OTGFS/HS\_DOEPTSIZx) on a control OUT endpoint must be programmed to be a non-zero value. When the application sets the SUPCNT bit to a non-zero value, the controller receives SETUP packets and writes them to the receive FIFO, irrespective of the NAK status bit and EPENA bit in the OTGFS/HS\_DOEPCTLx register. The SUPCNT bit is decremented each time the control endpoint receives a SETUP packet. If the SUPCNT bit is not programmed to a proper value before receiving a SETUP packet, the controller still receives the SETUP packet and decrements the SUPCNT bit, but the application may not be able to determine the exact number of SETUP packets received in the SETUP stage of a control transfer.
  - OTGFS/HS\_DOEPTSIZx.SUPCNT = 0x3
2. The application must allocate some extra space for the receive data FIFO to ensure that up to three SETUP packets can be received on a control endpoint
  - The space to be reserved is 13 WORDs. Four WORDs for one SETUP packet, one WORD for Setup stage and 8 WORDs for two extra SETUP packets among all control endpoints
  - Four WORDs per SETUP packet are required to store 8-byte SETUP data and 4-byte Transfer completed status and 4-byte SETUP status (SETUP packet mode). The controller must reserve this space to receive data
  - FIFO is used to write SETUP data only, and never for data packets
3. The application must read 2-WORDs SETUP packet from the receive data
4. The application must read and discard the Transfer Completed status WORD from the receive FIFO, and ignore the Transfer Completed interrupt due to this read operation.

#### 【Internal data flow】

1. When a SETUP packet is received, the controller writes the received data to the receive FIFO, without checking whether there is available space in the receive FIFO, irrespective of the NAK and Stall bits on the control endpoints.
  - The controller sets the IN NAK and OUT NAK bits for the control IN/OUT endpoints on which the SETUP packet was received.
2. For every SETUP packet received on the USB line, 3 WORDs of data are written to the receive FIFO, and the SUPCNT bit is decremented by 1 automatically.
  - The first WORD contains control information used internally by the controller
  - The second WORD contains the first 4 bytes of the SETUP command
  - The third WORD contains the last 4 bytes of the SETUP command
3. When the SETUP stage switches to data IN/OUT stage, the controller writes a SETUP status done WORD to the receive FIFO, indicating the end of the SETUP stage.
4. The application reads the SETUP packages through the AHB bus.
5. When the application pops the Setup stage done WORD from the receive FIFO, the controller interrupts the application through the SETUP interrupt bit in the OTGFS/HS\_DOEPINTx register, indicating that the application can start processing the SETUP packet received.
6. The controller clears the endpoint enable bit for control OUT endpoints.

#### 【Application programming process】

1. Program the OTGFS/HS\_DOEPTSIZx register
  - OTGFS/HS\_DOEPTSIZx.SUPCNT = 0x3

2. Wait for the RXFLVL interrupt bit in the OTGFS/HS\_GINTSTS register and read and empty the data packets from the receive FIFO (Refer to Read FIFO packets for details). This operation can be repeated several times.
3. When the SETUP interrupt bit is set in the OTGFS/HS\_DOEPINTx register, it indicates that the SETUP data transfer has been completed successfully. Upon this interrupt, the application must read the OTGFS/HS\_DOEPTSIZx register to determine the number of SETUP packets received, and process the last received SETUP packet.

Figure 21-12 SETUP data packet flowchart



## (2) Handling more than three consecutive SETUP packets

Per the USB 2.0 specification, typically, a host does not send more than three consecutive SETUP packets to the same endpoint during a SETUP packet error. However, the USB2.0 specification does not limit the number of consecutive SETUP packets a host can send to the same endpoint. If this condition occurs, the OTGFS controller generates an interrupt (B2BSTUP bit in the OTGFS/HS\_DOEPINTx register).

### 21.5.4.13 IN data transfers

This section describes the internal data flow during IN data transfers and how the application handles IN data transfers.

1. The application can either select a polling or an interrupt mode.
  - In polling mode, the application monitors the status of the endpoint transmit data FIFO by reading the OTGFS/HS\_DTXFSTSx register to determine whether there is enough space in the data FIFO.

- In interrupt mode, the application must wait for the TXFEMP interrupt bit in the OTGFS\_DIEPINTx register, and then read the OTGFS/HS\_DTXFSTSx register to determine whether there is enough space in the data FIFO.
  - To write a single non-zero-length data packet, there must be enough space to write the entire data packet in the data FIFO.
  - To write zero-length data packet, the application does not need to check the FIFO space.
2. Either way, when the application determines that there is enough space to write a transmit packet, the application can first write into the endpoint control register before writing the data into the data FIFO. Normally, except for setting the endpoint enable bit, the application must do a read modify write on the OTGFS/HS\_DIEPCTLx register to avoid modifying the contents of the register. If the space is enough, the application can write multiple data packets for the same endpoint into the transmit FIFO. For the periodic IN endpoints, the application must write packets for only one frame. It can write packets for the next periodic transfer only after the previous transfer has been completed.

#### 21.5.4.14 Non-periodic (bulk and control) IN data transfers

To initialize the controller after power-on reset, the application must perform the steps list in OTGFS/HS Initialization. Before communicating with a host, the controller must follow the steps defined in Device Initialization to initialize endpoints.

##### 【Application requirements】

1. For IN transfers, the Transfer Size bit in the Endpoint Transfer Size register indicates a payload that contains multiple largest-packet-size packets and a short packet. This short packet is transmitted at the end of the transfer.
  - To transmit several largest-packet-size packets and a short packet:  
Transfer size [epnum] =  $n * \text{mps}[\text{epnum}] + \text{sp}$  ( $n$  is an integer  $\geq 0$  and  $0 \leq \text{sp} < \text{mps}[\text{epnum}]$ )  
If ( $\text{sp} > 0$ ), then packet count [epnum] =  $n + 1$ . Otherwise, packet count [epnum] =  $n$
  - To transmit a single zero-length data packet:  
Transfer size [epnum] = 0x0  
Packet count [epnum] = 0x1
  - To transmit several largest-packet-size packets and a zero-length data packet (at the end of the transfer), the application must split the transfer into two parts. First send the largest-packet-size packets and then the zero-length data packet alone.  
First transfer: Transfer size [epnum] =  $n * \text{mps}[\text{epnum}]$ ; Packet count =  $n$ ;  
Second transfer: Transfer size [epnum] = 0x0; Packet count = 0x1;
2. If an endpoint is enabled for data transfers, the controller updates the Transfer size register. At the end of the IN transfer (indicated by endpoint disable interrupt bit), the application must read the Transfer size register to determine how much data in the transmit FIFO have already been sent on the USB line.
3. Data fetched in the transmit FIFO = Application-programmed initial transfer size – Controller-updated final transfer size
  - Data transmitted on USB = (Application-programmed initial packet count – Controller-updated final packet count) \*  $\text{mps}[\text{epnum}]$
  - Data to be transmitted on USB = Application-programmed initial transfer size – Data transmitted on USB

##### 【Internal data flow】

1. The application must set the transfer size and packet count bits in the endpoint control registers and enable the endpoint to transmit the data.
2. The application must also write the required data to the transmit FIFO of the endpoint.
3. Each time a data packet is sent to the transmit FIFO by the application the transfer size for this endpoint is decremented with the packet size. The application must continue to write data until the transfer size of the endpoint becomes 0. After writing data to the FIFO, the “packet count in the FIFO” is incremented (this is a 3-bit count for each IN endpoint transmit FIFO data packet, which is internally

maintained by the controller. For an IN endpoint FIFO, the maximum number of packets maintained by the controller at any time is 8). For non-zero-length packets, a separate flag is set for each FIFO, without any data in the FIFO.

4. After the data is written to the transmit FIFO, the controller reads them upon receiving an IN token. For each non-synchronous IN data packet transmitted with an ACK handshake signal, the number of packets for the endpoint is decremented by 1, until the packet count becomes 0. The packet count is not decremented due to a timeout.
5. For zero-length data packets (indicated by an internal zero-length flag), the controller sends zero-length packets according to the IN token, and the packet count is decremented automatically.
6. If there are no data in the FIFO on a received IN token and the packet count for the endpoint is 0, the controller generates an “IN token received when FIFO is empty” interrupt, and the NAK bit for the endpoint is not set. The controller responds with a NAK handshake signal to the non-synchronous endpoints on the USB.
7. The controller rewinds the FIFO pointers internally and no timeout interrupt is generated except for the control IN endpoints.
8. When the transfer size is 0 and the packet count is also 0, the Transfer completed interrupt is generated and the endpoint enable bit is cleared.

#### **【Application programming sequence】**

1. Program the OTGFS/HS\_DIEPTSI $x$  register according to the transfer size and the corresponding packet count.
2. Program the OTGFS/HS\_DIEPCTL $x$  register according to the endpoint characteristics and set the CNAK and endpoint enable bits.
3. While sending non-zero-length data packets, the application must poll the OTGFS/HS\_DTXFSTS $x$  register (where  $n$  is the FIFO number related to that endpoint) to determine whether there is enough space in the data FIFO. The application can also use the TXFEMP bit in the OTGFS/HS\_DIEPINT $x$  register before writing data.

### **21.5.4.15 Non-synchronous OUT data transfers**

To initialize the controller after power-on reset, the application must perform the steps list in “OTGFS/HS Initialization”. Before communicating with a host, the application must initialize endpoints based on the process described in “Endpoint Initialization” and by referring to “Read FIFO packets”. This section describes a regular non-synchronous OUT transfers (control, bulk or interrupt transfers).

#### **【Application requirements】**

1. For OUT data transfers, the transfer size of the endpoint transfer register must be set to a multiple of the largest packet size for the endpoint, and adjusted to the WORD boundary.

```

if (mps[epnum] mod 4) == 0
    transfer size[epnum] = n * (mps[epnum]) //WORD Aligned
else
    transfer size[epnum] = n * (mps[epnum] + 4 - (mps[epnum] mod 4)) //Non WORD
    Aligned
    packet count[epnum] = n
    n > 0
  
```

2. When an OUT endpoint interrupt occurs, the application must read the endpoint's transfer size register to calculate the size of the data in the memory. The received payload size must be less than the programmed transfer size.
  - Payload size in memory = Application-programmed initial transfer size – Controller-updated final transfer size
  - Number of USB packets the payload was received = Application-programmed initial packet count – Controller-updated final packet count

#### **【Internal data flow】**

1. The application must set the transfer size and packet count bits in the endpoint control registers, clear the NAK bit, and enable the endpoint to receive the data.

2. Once the NAK bit is cleared, the controller starts receiving data and writes it to the receive FIFO as long as there is available space in the receive FIFO. For each data packet received on the USB line, the data packet and its status are written to the receive FIFO. The packet count is decremented by 1 each time a packet (largest packet size or a short packet) is written to the receive FIFO.
  - OUT data packets received with Bad Data CRC are emptied from the receive FIFO
  - After sending an ACK to the data packet on the USB, the controller discards non-synchronous OUT data packets that the host (which cannot detect the ACK) re-transmits. The application does not detect multiple consecutive OUT data packets on the same endpoint with the same data PID. In this case, the packet count is not decremented.
  - If there is no space in the receive FIFO, synchronous or non-synchronous data packets are ignored and not written to the receive FIFO. Besides, the non-synchronous OUT tokens receive a NAK handshake response.
  - In all the above-mentioned cases, the packet count is not decremented because no data is written to the receive FIFO.
3. When the packet count becomes 0 or when a short packet is received on the endpoint, the NAK bit for the endpoint is set. Once the NAK bit is set, the synchronous or non-synchronous data packets are ignored and not written to the receive FIFO, and non-synchronous OUT tokens receive a NAK handshake response.
4. After the data is written to the receive FIFO, the application reads the data from the receive FIFO and writes it to the external memory, once packet at a time per endpoint.
5. At the end of data packet write to the external memory, the transfer size for the endpoint is decremented with the size of the written packet.
6. The OUT data transfer completed mode for an OUT endpoint is written to the receive FIFO in one of the following conditions:
  - The transfer size and packet count are both 0
  - The last OUT data packet written to the receive FIFO is a short packet ( $0 \leq$  data packet size < largest packet size)
7. When the application pops this entry (OUT data transfer complete), a transfer completed interrupt is generated and the endpoint enable bit is cleared.

#### 【Application programming sequence】

1. Program the OTGFS/HS\_DOEPTSIZx register with the transfer size and the corresponding packet count.
2. Program the OTGFS/HS\_DOEPCTLx register with the endpoint characteristics, and set the endpoint enable and ClearNAK bits.
  - OTGFS/HS\_DOEPCTLx.EPENA = 0x1
  - OTGFS/HS\_DOEPCTLx.CNAK = 0x1
3. Wait for the RXFLVL interrupt in the OTGFS/HS\_GINTSTS register, and read out all data packets from the receive FIFO.  
This step can be repeated, depending on the transfer size
4. When the XFERC interrupt is set in the OTGFS/HS\_DOEPINTx register, it indicates a successful completion of the non-synchronous OUT data transfer. Read the OTGFS/HS\_DOEPTSIZx register to determine how much data has been received.

#### 【Bulk OUT transfer】

*Figure 21-13* describes the reception of a single bulk OUT data packet from the USB to the AHB and shows the events involved in the process.

Figure 21-13 BULK OUT transfer block diagram



After a SetConfiguration/SetInterface command is received, the application initializes all OUT endpoints by setting CNAK = 0x1 and EPENA = 0x1 in the OTGFS/HS\_DOEPCTLx register, and setting the XFERSIZE and PKTCNT bits in the OTGFS/HS\_DOEPTSIZx register.

1. The host attempts to send data (OUT token) to the endpoint
2. When the controller receives the OUT token on the USB, it stores data in the receive FIFO because the FIFO has free space.
3. Upon writing the complete data in the receive FIFO, the controller then triggers the RXFLVL interrupt bit in the OTGFS/HS\_GINTSTS register.
4. Upon receiving the packet count of USB packets, the controller internally sets the NAK bit for the endpoint to prevent it from receiving any more packets.
5. The application processes the interrupt and reads the data from the receive FIFO.
6. When the application reads all the data (equivalent to XFERSIZE), the controller generates an XFERC interrupt in the OTGFS/HS\_DOEPINTx register.
7. The application processes the interrupt and uses the XFERC bit in the OTGFS/HS\_DOEPINTx register to judge that the expected transfer is already complete.

#### 21.5.4.16 Synchronous OUT data transfers

To initialize the controller after power-on reset, the application must perform the steps list in “OTGFS/HS Initialization”. Before communicating with a host, the application must initialize endpoints based on the process described in “Endpoint Initialization” and by referring to “Read FIFO packets”. This section describes a regular synchronous OUT transfers.

### 【Application requirements】

1. All the application requirements are the same as that of non-synchronous OUT data transfers.
2. For synchronous OUT data transfers, the transfer size and packet count must be set to the number of the largest-packet-size packets that can be received in a single frame and not exceed this size. Synchronous OUT data transfer cannot span more than one frame.
  - $1 \leq \text{packet count [epnum]} \leq 3$
3. If the device supports the synchronous OUT endpoints, the application must read all synchronous OUT data packets from the receive FIFO before the end of the periodic frame (EOPF interrupt in the OTGFS/HS\_GINTSTS register)
4. To receive data in the subsequent frame, a synchronous OUT endpoint must be enabled before the generation of the EOPF and SOF interrupt in the OTGFS/HS\_GINTSTS register.

### 【Internal data flow】

1. The internal data flow for the synchronous OUT endpoints is the same as that for the non-synchronous OUT endpoints, just for a few differences.
2. When the synchronous OUT endpoint is enabled by setting the endpoint enable bit and by clearing the NAK bit, the even/odd frame bits are also set properly. The controller can receive data on a synchronous OUT endpoint in a particular frame only when the following condition is met:
  - Even/Odd microframe (OTGFS/HS\_DOEPCTLx) =SOFFN[0] (OTGFS\_DSTS)
3. When the application completely reads the synchronous OUT data packet (data and status) from the receive FIFO, the controller updates the RXDPID bit in the OTGFS/HS\_DOEPTSIZx register based on the data PID of the last synchronous OUT data packet read from the receive FIFO.

### 【Application programming sequence】

1. Program the transfer size and the corresponding packet count of the OTGFS\_DOEPTSIZx register
2. Program the OTGFS/HS\_DOEPCTLx register with the endpoint enable, ClearNAK and Even/Odd frame bits
  - Endpoint enable = 0x1
  - CNAK = 0x1
  - Even/Odd frame = (0x0: Even; 0x1: Odd)
3. Wait for the RXFLVL interrupt in the OTGFS/HS\_GINTSTS register, and read all the data packets from the receive FIFO. See "Read FIFO" for more information
  - This step can be repeated several times, depending on the transfer size
4. When the XFERC interrupt is set in the OTGFS/HS\_DOEPINTx register, it indicates the completion of the synchronous OUT data transfers. But this interrupt does not necessarily mean that the data in memory are good.
5. This interrupt signal cannot always be detected by the synchronous OUT data transfers. However, the application can detect the INCOMPISOOUT interrupt in the OTGFS/HS\_GINTSTS register. See "Incomplete synchronous OUT data transfers" for more information.
6. Read the OTGFS/HS\_DOEPTSIZx register to determine the received transfer size and to determine whether the data received in the frame are valid or not. The application must treat the data received in memory as valid only when one of the following conditions is met:
  - OTGFS/HS\_DOEPTSIZx.RXDPID = 0xD0 and the USB packet count in which the payload was received =0x1
  - OTGFS/HS\_DOEPTSIZx.RXDPID = 0xD1 and the USB packet count in which the payload was received =0x2
  - OTGFS/HS\_DOEPTSIZx.RXDPID = 0xD2 and the USB packet count in which the payload was received =0x3

The number of USB packets in which the payload was received= Application-programmed initial packet count – Controller-updated final packet count

The application discards invalid data packets.

### 21.5.4.17 Enable synchronous endpoints

After sending a Set interface control command to the device, a host enables the synchronous endpoints. Then the host can send the initial synchronous IN token in any frame before transmission in the sequence of BIinterval.

Instead, synchronous support in the OTGFS/HS controller is based on a single-transfer level. The application must re-configure the controller on every frame. The OTGFS/HS controller enables the synchronous endpoint of the frame before the frame to be transmitted.

For example, to send data on the frame n, enable the endpoint of the frame n-1. Additionally, the OTGFS/HS controller schedules the synchronous transfers by setting Even/Odd frame bits.

#### 【Isochronous IN transfer interrupt】

The following interrupts must be processed to ensure successful scheduling of the synchronous transfers.

- XFERC interrupt in the OTGFS/HS\_DIEPINTx register (for endpoints)
- INCOMPISOIN interrupt in the OTGFS/HS\_GINTSTS register (for global interrupts)

#### 【Handling isochronous IN transfers】

The following steps must be performed to handle a synchronous IN transfer:

1. Unmask the incomplSOOUT interrupt in the OTGFS/HS\_GINTSTS register by setting the INCOMISOINMSK interrupt bit in the OTGFS/HS\_GINTMSK register
2. Unmask the XFERC interrupt in the OTGFS/HS\_DIEPINTx register by setting the XFERCMSK bit in the OTGFS/HS\_DIEPMSK register
3. Enable synchronous endpoints with the following steps:

- Program the OTGFS/HS\_DIEPTSI<sub>Z</sub>x register

OTGFS/HS\_DIEPTSI<sub>Z</sub>x.XFERSIZE= n \* OTGFS/HS\_DIEPCTLx.MPS + sp, where 0 <= n <= 3 and 0 <= sp < OTGFS/HS\_DIEPCTLx.MPS. When the transfer size in a frame is less than that of the MPS bit in the OTGFS/HS\_DIEPCTLx register, n=0; When the transfer size in a frame is a multiple of that of the MPS bit in the OTGFS/HS\_DIEPCTLx register, sp=0.

OTGFS/HS\_DIEPTSI<sub>Z</sub>x.PKTCNT = 1

The MC bit in the OTGFS/HS\_DIEPTSI<sub>Z</sub>x register is set the same value as that of the PKTCNT bit in the OTGFS/HS\_DIEPTSI<sub>Z</sub>x register.

- Program the OTGFS/HS\_DIEPCTLx register

Read the OTGFS/HS\_DSTS register to determine the current frame number

Program the OTGFS/HS\_DIEPCTLx with the maximum packet size (MPS bit)

Set USBACTEP = 0x1 in the OTGFS/HS\_DIEPCTLx register

Set EPTYPE = 0x1 in the OTGFS/HS\_DIEPCTLx register, marking synchronization

Set the FIFO number of the endpoint through the TXFNUM bit in the OTGFS/HS\_DIEPCTLx register

Set CNAK = 0x1 in the OTGFS/HS\_DIEPCTLx register

If SOFFN[0] = 0x0 in OTGFS/HS\_DSTS, then SETEVENFR = 0x1 in OTGFS/HS\_DIEPCTLx (otherwise, SETEVENFR = 0x1 in OTGFS/HS\_DIEPCTLx)

If SOFFN[0] = 0x1 in OTGFS/HS\_DSTS, then SETODDFR = 0x1 in OTGFS\_DIEPCTLx (otherwise, SETODDFR = 0x0 in OTGFS/HS\_DIEPCTLx)

Set EPENA = 0x1 in OTGFS/HS\_DIEPCTLx

4. Write endpoint data to the corresponding transmit FIFO

For example, write address ranges are as follows:

- EP1 corresponding to 0x2000 - 0x2FFC
- EP2 corresponding to 0x3000 - 0x3FFC
- EP3 corresponding to 0x3000 - 0x3FFC
- ...

5. Wait for interrupts

- When an interrupt is generated (XFERC bit in OTGFS/HS\_DIEPINTx register), clear the XFERC interrupt; for the following transaction, repeat step 3-5 until the completion of data transfers.

- When an interrupt is generated (INCOMPISOIN bit in OTGFS/HS\_GINTSTS register), clear the INCOMPISOIN interrupt; For any synchronous IN endpoint, when Odd/Even bits match the current frame number bit 0, and when the endpoint remains enabled, the controller generates an interrupt at the end of the frame. This interrupt is generated on one of the following conditions:
  - (1) There is no token in a frame
  - (2) Late data write to the receive FIFO. An IN token has arrived before the completion of data write
  - (3) IN token error

The INCOMPISOIN interrupt in the OTGFS/HS\_GINTSTS register is a global interrupt. Therefore, when more than one synchronous endpoints are in active state, the application must determine which one of the synchronous IN endpoints has not yet completed data transfers.

To achieve this, read the DSTS and DIEPCTLx bits of all synchronous endpoints. If the current endpoint has been enabled, and the read value of the SOFFN bit in the OTGFS/HS\_DSTS register is equal to the target frame number of the endpoint, it indicates that this endpoint has not finished data transfers. The application must keep track of and update the target frame number of the synchronous endpoint.

If data transfer is not yet complete on an endpoint, then Odd/Even bits have to be toggled.

Next:

- (1) When the DPID is set to 1 (an odd frame) in the OTGFS/HS\_DIEPCTLx register, write 1 to the SETD0PID bit in the OTGFS/HS\_DIEPCTLx register makes it an even frame, then data transmission starts when there is an IN token input in the next frame.
- (2) When the DPID is set to 0 in the OTGFS/HS\_DIEPCTLx register, write 1 to the SETD1PID bit in the OTGFS/HS\_DIEPCTLx register makes it an odd frame, then data transmission starts when there is an IN token input in the next frame.

#### 21.5.4.18 Incomplete isochronous OUT data transfers

To initialize the controller after power-on reset, the application must perform the steps list in OTGFS/HS Initialization. Before communicating with a host, the controller must follow the steps defined in Endpoint Initialization to initialize endpoints. This section describes the application programming sequence when the controller drops synchronous OUT data packets.

##### 【Internal data flow】

- For synchronous OUT endpoints, the XFERC interrupt (in the OTGFS/HS\_DOEPINTx register) may not always be generated. If the controller drops synchronous OUT data packets, the application may fail to detect the XFERC interrupt in the OTGFS/HS\_DOEPINTx register.
  - When the receive FIFO cannot accommodate the complete ISO OUT data packet, the controller drops the received ISO OUT data.
  - When the synchronous OUT data packet is received with CRC errors.
  - When the synchronous OUT token received by the controller is corrupted.
  - When the application is very slow in reading the receive FIFO
- When the controller detects the end of periodic frames before transfer complete to all synchronous OUT endpoints, an interrupt of incomplete synchronous OUT data is generated, indicating that an XFERC interrupt in the OTGFS/HS\_DOEPINTx register is not set on at least one of the synchronous OUT endpoints. At this point, the endpoint with the incomplete data transfer remains enabled, but no valid transfers are in progress on this endpoint.

##### 【Application programming sequence】

- The assertion of the incomplete synchronous OUT data interrupt indicates that at least one synchronous OUT endpoint has an incomplete data transfer in the current frame.
- If this occurs because the synchronous OUT data is not completely read out from the endpoint, the application must empty all synchronous OUT data (data and status) in the receive FIFO before proceeding.
- When all data are read from the receive FIFO, the application can detect the XFERC interrupt in the OTGFS/HS\_DOEPINTx register. In this case, the application must re-enable the endpoint to receive the synchronous OUT data in the next frame by following the steps listed in “SETUP/Data IN/Status OUT”
- When it receives an incomplete synchronous OUT data interrupt, the application must read the control registers of all synchronous OUT endpoints to determine which one of the endpoints has an

incomplete data transfer in the current frame. An endpoint transfer is regarded as incomplete if both of the following conditions are met:

- OTGFS/HS\_DOEPCCTLx. Even/Odd frame bit= OTGFS\_DSTS.SOFFN[0]
- OTGFS/HS\_DOEPCCTLx. Endpoint enable = 0x1

4. The previous step must be performed before the SOF interrupt of the GINTSTS register is detected to ensure that the current frame number is not changed.
5. For synchronous OUT endpoints with incomplete transfers, the application must drop the data in memory, and disable the endpoint through the endpoint disable bit in the OTGFS/HS\_DOEPCCTLx register.
6. Wait for the endpoint disable interrupt in the OTGFS/HS\_DOEPINTx register, and enable the endpoint to receive new data in the next frame by following the steps listed in “SETUP/Data IN/Status OUT”. Because the controller can take some time to disable the endpoint, the application may not be able to receive the data in the next frame after receiving wrong synchronous data.

#### 21.5.4.19 Incomplete isochronous IN data transfers

This section describes how the application behaves on incomplete synchronous IN transfers.

##### 【Internal data flow】

1. Synchronous IN transfers are incomplete on one of the following conditions:
  - The controller receives corrupted synchronous IN tokens from more than one synchronous IN endpoints. In this case, the application can detect the incomplete synchronous IN transfer interrupt in the GINTSTS register.
  - The application is slow in writing complete data to the transmit FIFO, and an IN token is received before the completion of data write. In this case, the application can detect the INTKNTXFEMP interrupt in the OTGFS/HS\_DIEPINTx register. The application ignores this interrupt, which will result in the generation of the incomplete synchronous IN transfer interrupt (in OTGFS/HS\_GINTSTS register). The controller responds to the received IN token by sending a zero-length data packet to the USB.
2. Either way, the application must stop writing the transmit FIFO as soon as possible.
3. The application must set the NAK and disable bits of the endpoints.
4. The controller disables the endpoint, clears the disable bit, and triggers the endpoint disable interrupt.

##### 【Application programming sequence】

1. When the transmit FIFO becomes empty, the application ignores the INTKNTXFEMP interrupt (in the OTGFS/HS\_DIEPINTx register) from any synchronous IN endpoint because this can trigger the incomplete synchronous IN interrupt.
2. The incomplete synchronous IN transfer interrupt (in the OTGFS/HS\_GINTSTS register) indicates that at least one synchronous IN endpoint is with incomplete synchronous IN transfers.
3. The application must read the endpoint control registers of all synchronous IN endpoints to determine which one is with incomplete synchronous IN transfers.
4. The application must write data to the periodic transmit FIFO of the endpoint.
5. Disable these endpoints by setting the following bits in the OTGFS/HS\_DIEPCTLx register
  - OTGFS/HS\_DIEPCTLx.SETNAK = 0x1
  - OTGFS/HS\_DIEPCTLx.endpoint enable = 0x1
6. The endpoint disable interrupt in the DIEPINTx register indicates that the controller has disabled the endpoint.
7. At this point, the application must empty the data in the associated transmit FIFO or overwrite the existing data in the FIFO by enabling the endpoint for a new transfer in the next frame. The application must refresh the data through the OTGFS/HS\_GRSTCTL register.

#### 21.5.4.20 Periodic IN (interrupt and isochronous) data transfers

This section describes a typical periodic IN data transfer.

To initialize the controller after power-on reset, the application must perform the steps list in OTGFS/HS Initialization. Before communicating with a host, the controller must follow the steps defined in Endpoint Initialization to initialize endpoints.

### 【Application requirements】

1. Application requirements in “Non-periodic (bulk and control) IN data transfers” also apply to periodic IN data transfers, except for a slight difference of requirement 2.
- The application can only transmit multiples of largest-packet-size data packets, and a short packet. To transmit several largest-packet-size data packets and a short packet, the following conditions must be met:
 

Transfer size [epnum] =  $n * \text{mps}[epnum] + sp$  (where  $n$  and  $i$  are integers  $\geq 0$ , and  $0 \leq sp < \text{mps}[epnum]$ )

If ( $sp > 0$ ), packet count [epnum] =  $n + 1$ . Otherwise, packet count [epnum] =  $n$ ,  $mc[epnum] = \text{packet count}[epnum]$

  - The application cannot transmit a zero-length data packet at the end of a transfer. But it can transmit a single zero-length data packet in itself, provided packet count [epnum] = 1,  $mc[epnum] = \text{packet count}[epnum]$
2. The application can only schedule data transfers of one frame at a time
  - $(OTGFS/HS\_DIEPTSIx.MC - 1) * OTGFS/HS\_DIEPCTLx.MPS \leq OTGFS/HS\_DIEPTSIx.XFERSIZ \leq OTGFS/HS\_DIEPTSIx.MC * OTGFS/HS\_DIEPCTLx.MPS$
  - $OTGFS/HS\_DIEPTSIx.PKTCNT = OTGFS/HS\_DIEPTSIx.MC$
  - If  $OTGFS/HS\_DIEPTSIx.XFERSIZ < OTGFS/HS\_DIEPTSIx.MC * OTGFS/HS\_DIEPCTLx.MPS$ , the last data packet of the transfer is a short packet.
3. For periodic IN endpoints, one-frame data must be prefetched before the data transfer in the next frame. This can be done by enabling periodic IN endpoint 1 frame before the scheduling of the frame to be transmitted.
4. The complete data to be transmitted in a frame must be written to the transmit FIFO by the application before the periodic IN token is received. Even when one-WORD data to be transmitted per frame is missing in the transmit FIFO while the periodic IN token is received, the controller behaves as when the FIFO is empty. When the transmit FIFO is empty, a zero-length data packet would be transmitted on the USB, and An NAK handshake signal would be transmitted for INTR IN endpoints.

### 【Internal data flow】

1. The application must set the transfer size and packet count bits of the endpoint registers, and enable the endpoint to transmit the data.
2. The application must also write the required data to the associated transmit FIFO.
3. Each time the application writes a packet to the transmit FIFO, the transfer size for the endpoint is decremented by the packet size. Continue to write data until the transfer size for the endpoint becomes 0
4. When an IN token for a periodic endpoint is received, the application writes the data to the FIFO (If any). If the complete data for the frame is not present in the FIFO, the controller generates an INTKNTXFEMP interrupt.
  - A zero-length data packet is transmitted on the USB for synchronous IN endpoints
  - An NAK handshake signal is transmitted on the USB for interrupt IN endpoints.
5. The packet count for the endpoints is decremented by one under the following conditions:
  - For synchronous endpoints, when a zero-or non-zero-length data packet is transmitted
  - For interrupt endpoints, when an ACK handshake is transmitted
  - When the transfer size and packet count are both 0, the transfer complete interrupt for the endpoint is generated and the endpoint enable bit is cleared.
6. In the “Periodic frame interval” (by the PERFRINT bit in the OTGFS/HS\_DCFG register), when the controller finds non-empty any one of the IN endpoint FIFOs scheduled for the current frame non-empty, the controller generates an INCOMPISOIN interrupt in the OTGFS/HS\_GINTSTS register.

### 【Application programming sequence (frame transfers)】

1. Program the OTGFS/HS\_DIEPTSIx register
2. Program the OTGFS/HS\_DIEPCTLx register based on endpoint characteristics, and set the CNAK and endpoint enable bits
3. Write the data to be transmitted into the transmit FIFO.
4. The assertion of the INTKNTXFEMP interrupt indicates that the application has not yet written all data to be transferred into the transmit FIFO.

5. If the interrupt endpoint is already enabled while this interrupt is detected, ignore the interrupt. If it is not enabled, enable the endpoint to transmit data on the next IN token. If it is enabled while the interrupt is detected, refer to “Incomplete synchronous IN data transfers”.
6. When the interrupt IN endpoint is set as a periodic endpoint, the controller internally can process the timeout on the interrupt IN endpoint, without the need of the application intervention. Therefore, the application can never detect the TIMEOUT interrupt (in the OTGFS/HS\_DIEPINTx register) on the periodic interrupt IN endpoints.
7. The assertion of the XFERC interrupt in the OTGFS/HS\_DIEPINTx register but without the INTKNTXFEMP interrupt indicates the successful completion of a synchronous IN transfer. When reading the OTGFS/HS\_DIEPTSIZx register, only transfer size =0 and packet count =0 indicate that all data are transmitted on the USB line.
8. The assertion of the XFERC interrupt in the OTGFS/HS\_DIEPINTx register, with or without the INTKNTXFEMP interrupt, indicates the successful completion of an interrupt IN transfer. When reading the OTGFS/HS\_DIEPTSIZx register, only transfer size =0 and packet count =0 indicate that all data are transmitted on the USB line.
9. The assertion of the INCOMPISOIN interrupt but without the above-mentioned interrupts indicates that the controller did not receive at least one periodic IN token in the current frame. Refer to “Incomplete synchronous IN data transfers” for more information on synchronous IN endpoints.

## 21.6 OTGFS/HS control and status registers

The application controls the OTGFS controller by reading from and writing to the control and status registers (CSR<sub>x</sub>) through the AHB slave interface. These registers are accessible by 32 bits, and the addresses are 32-bit aligned.

Only the controller global, power and clock control, data FIFO access and host port control and status registers are active in both host and device modes. When the OTGFS/HS controller operates in either host or device mode, the application must not access the register group from the other mode. If an illegal access occurs, a mode mismatch interrupt is generated and the MODMIS bit (in the OTGFS/HS\_GINTSTS register) is affected.

When the controller switches from one mode to the other, the registers in the new mode must be re-initialized as they are after a power-on reset. These peripheral registers must be accessed by words (32-bit)

### 21.6.1 CSR register map

The host and device mode registers occupy different addresses. All registers are located in the AHB clock domain.

Figure 21-14 CSR memory map



x = 7 in device mode, x = 15 in host mode.

The OTGFS/HS control and status registers contain OTGFS global register, host mode register, device mode register, data FIFO register, power and clock control register.

1. OTGFS/HS global registers: They are active in both host and device modes. The register acronym is G.
2. Host-mode registers: They must be programmed every time the controller changes to host mode. The register acronym is H.
3. Device-mode registers: They must be programmed every time the controller changes to device mode. The register acronym is D.
4. Data FIFO access registers: These registers are valid in both host and device modes, and are used to read or write the FIFO for a specific endpoint or channel in a given direction. If a host channel is of type IN, the FIFO can only be read. Similarly, if a host channel is of type OUT, the FIFO can only be written.
5. Power and clock control register: There is only one register for power and clock control. It is valid in both host and device modes.

## 21.6.2 OTGFS/HS register address map

Table 21-5 shows the USB OTG register map and their reset values.

These peripheral registers must be accessed by words (32 bits).

Table 21-5 OTGFS/HS register map and reset values

| Register         | Offset | Reset value |
|------------------|--------|-------------|
| OTGFS/HS_GOTGCTL | 0x000  | 0x0001 0000 |

|                    |       |             |
|--------------------|-------|-------------|
| OTGFS/HS_GOTGINT   | 0x004 | 0x0000 0000 |
| OTGFS/HS_GAHBCFG   | 0x008 | 0x0000 0000 |
| OTGFS_GUSBCFG      | 0x00C | 0x0000 1440 |
| OTGHS_GUSBCFG      | 0x00C | 0x0000 1400 |
| OTGFS/HS_GRSTCTL   | 0x010 | 0x8000 0000 |
| OTGFS/HS_GINTSTS   | 0x014 | 0x0400 0020 |
| OTGFS/HS_GINTMSK   | 0x018 | 0x0000 0000 |
| OTGFS/HS_GRXSTSR   | 0x01C | 0x0000 0000 |
| OTGFS/HS_GRXSTSP   | 0x020 | 0x0000 0000 |
| OTGFS/HS_GRXFSIZ   | 0x024 | 0x0000 0200 |
| OTGFS/HS_GNPTXFSIZ | 0x028 | 0x0000 0200 |
| OTGFS/HS_GNPTXSTS  | 0x02C | 0x0008 0200 |
| OTGFS/HS_GCCFG     | 0x038 | 0x0000 0000 |
| OTGFS/HS_GUID      | 0x03C | 0x0000 1000 |
| OTGFS/HS_HPTXFSIZ  | 0x100 | 0x0200 0600 |
| OTGFS/HS_DIEPTXF1  | 0x104 | 0x0200 0400 |
| OTGFS/HS_DIEPTXF2  | 0x108 | 0x0200 0400 |
| OTGFS/HS_DIEPTXF3  | 0x10C | 0x0200 0400 |
| OTGFS/HS_DIEPTXF4  | 0x110 | 0x0200 0400 |
| OTGFS/HS_DIEPTXF5  | 0x114 | 0x0200 0400 |
| OTGFS/HS_DIEPTXF6  | 0x118 | 0x0200 0400 |
| OTGFS/HS_DIEPTXF7  | 0x11C | 0x0200 0400 |
| OTGFS/HS_DIEPTXF8  | 0x120 | 0x0200 0400 |
| OTGFS/HS_HCFG      | 0x400 | 0x0000 0000 |
| OTGFS/HS_HFIR      | 0x404 | 0x0000 EA60 |
| OTGFS/HS_HFNUM     | 0x408 | 0x0000 3FFF |
| OTGFS/HS_HPTXSTS   | 0x410 | 0x0008 0100 |
| OTGFS/HS_HAINT     | 0x414 | 0x0000 0000 |
| OTGFS/HS_HAINTMSK  | 0x418 | 0x0000 0000 |
| OTGFS/HS_HPRT      | 0x440 | 0x0000 0000 |
| OTGFS/HS_HCCHAR0   | 0x500 | 0x0000 0000 |
| OTGFS/HS_HCINT0    | 0x508 | 0x0000 0000 |
| OTGFS/HS_HCSPLT0   | 0x504 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK0 | 0x50C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ0   | 0x510 | 0x0000 0000 |
| OTGHS_HCDMA0       | 0x514 | 0x0000 0000 |
| OTGFS/HS_HCCHAR1   | 0x520 | 0x0000 0000 |
| OTGFS/HS_HCINT1    | 0x528 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK1 | 0x52C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ1   | 0x530 | 0x0000 0000 |
| OTGHS_HCDMA1       | 0x534 | 0x0000 0000 |

|                    |       |             |
|--------------------|-------|-------------|
| OTGFS/HS_HCCHAR2   | 0x540 | 0x0000 0000 |
| OTGFS/HS_HCINT2    | 0x548 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK2 | 0x54C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ2   | 0x550 | 0x0000 0000 |
| OTGHS_HCDMA2       | 0x554 | 0x0000 0000 |
| OTGFS/HS_HCCHAR3   | 0x560 | 0x0000 0000 |
| OTGFS/HS_HCINT3    | 0x568 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK3 | 0x56C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ3   | 0x570 | 0x0000 0000 |
| OTGHS_HCDMA3       | 0x574 | 0x0000 0000 |
| OTGFS/HS_HCCHAR4   | 0x580 | 0x0000 0000 |
| OTGFS/HS_HCINT4    | 0x588 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK4 | 0x58C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ4   | 0x590 | 0x0000 0000 |
| OTGHS_HCDMA4       | 0x594 | 0x0000 0000 |
| OTGFS/HS_HCCHAR5   | 0x5A0 | 0x0000 0000 |
| OTGFS/HS_HCINT5    | 0x5A8 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK5 | 0x5AC | 0x0000 0000 |
| OTGFS/HS_HCTSIZ5   | 0x5B0 | 0x0000 0000 |
| OTGHS_HCDMA5       | 0x5B4 | 0x0000 0000 |
| OTGFS/HS_HCCHAR6   | 0x5C0 | 0x0000 0000 |
| OTGFS/HS_HCINT6    | 0x5C8 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK6 | 0x5CC | 0x0000 0000 |
| OTGFS/HS_HCTSIZ6   | 0x5D0 | 0x0000 0000 |
| OTGHS_HCDMA6       | 0x5D4 | 0x0000 0000 |
| OTGFS/HS_HCCHAR7   | 0x5E0 | 0x0000 0000 |
| OTGFS/HS_HCINT7    | 0x5E8 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK7 | 0x5EC | 0x0000 0000 |
| OTGFS/HS_HCTSIZ7   | 0x5F0 | 0x0000 0000 |
| OTGHS_HCDMA7       | 0x5F4 | 0x0000 0000 |
| OTGFS/HS_HCCHAR8   | 0x600 | 0x0000 0000 |
| OTGFS/HS_HCINT8    | 0x608 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK8 | 0x60C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ8   | 0x610 | 0x0000 0000 |
| OTGHS_HCDMA8       | 0x614 | 0x0000 0000 |
| OTGFS/HS_HCCHAR9   | 0x620 | 0x0000 0000 |
| OTGFS/HS_HCINT9    | 0x628 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK9 | 0x62C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ9   | 0x630 | 0x0000 0000 |
| OTGHS_HCDMA9       | 0x634 | 0x0000 0000 |
| OTGFS/HS_HCCHAR10  | 0x640 | 0x0000 0000 |

|                     |       |             |
|---------------------|-------|-------------|
| OTGFS/HS_HCINT10    | 0x648 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK10 | 0x64C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ10   | 0x650 | 0x0000 0000 |
| OTGHS_HCDMA10       | 0x654 | 0x0000 0000 |
| OTGFS/HS_HCCHAR11   | 0x660 | 0x0000 0000 |
| OTGFS/HS_HCINT11    | 0x668 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK11 | 0x66C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ11   | 0x670 | 0x0000 0000 |
| OTGHS_HCDMA11       | 0x674 | 0x0000 0000 |
| OTGFS/HS_HCCHAR12   | 0x680 | 0x0000 0000 |
| OTGFS/HS_HCINT12    | 0x688 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK12 | 0x68C | 0x0000 0000 |
| OTGFS/HS_HCTSIZ12   | 0x690 | 0x0000 0000 |
| OTGHS_HCDMA12       | 0x694 | 0x0000 0000 |
| OTGFS/HS_HCCHAR13   | 0x6A0 | 0x0000 0000 |
| OTGFS/HS_HCINT13    | 0x6A8 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK13 | 0x6AC | 0x0000 0000 |
| OTGFS/HS_HCTSIZ13   | 0x6B0 | 0x0000 0000 |
| OTGHS_HCDMA13       | 0x6B4 | 0x0000 0000 |
| OTGFS/HS_HCCHAR14   | 0x6C0 | 0x0000 0000 |
| OTGFS/HS_HCINT14    | 0x6C8 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK14 | 0x6CC | 0x0000 0000 |
| OTGFS/HS_HCTSIZ14   | 0x6D0 | 0x0000 0000 |
| OTGHS_HCDMA14       | 0x6D4 | 0x0000 0000 |
| OTGFS/HS_HCCHAR15   | 0x6E0 | 0x0000 0000 |
| OTGFS/HS_HCINT15    | 0x6E8 | 0x0000 0000 |
| OTGFS/HS_HCINTMSK15 | 0x6EC | 0x0000 0000 |
| OTGFS/HS_HCTSIZ15   | 0x6F0 | 0x0000 0000 |
| OTGHS_HCDMA15       | 0x6F4 | 0x0000 0000 |
| OTGFS/HS_DCFG       | 0x800 | 0x0820 0000 |
| OTGFS/HS_DCTL       | 0x804 | 0x0000 0002 |
| OTGFS/HS_DSTS       | 0x808 | 0x0000 0010 |
| OTGFS/HS_DIEPMSK    | 0x810 | 0x0000 0000 |
| OTGFS/HS_DOEPMSK    | 0x814 | 0x0000 0000 |
| OTGFS/HS_DAINT      | 0x818 | 0x0000 0000 |
| OTGFS/HS_DAINTMSK   | 0x81C | 0x0000 0000 |
| OTGFS/HS_DIEPEMPMSK | 0x834 | 0x0000 0000 |
| OTGHS_DEACHINT      | 0x838 | 0x0000 0000 |
| OTGHS_DEACHINTMSK   | 0x83C | 0x0000 0000 |
| OTGHS_DIEPEACHMSK1  | 0x844 | 0x0000 0000 |
| OTGHS_DOEPEACHMSK1  | 0x884 | 0x0000 0000 |

|                    |       |             |
|--------------------|-------|-------------|
| OTGFS/HS_DIEPCTL0  | 0x900 | 0x0000 0000 |
| OTGFS/HS_DIEPINT0  | 0x908 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ0 | 0x910 | 0x0000 0000 |
| OTGHS_DIEPDMA0     | 0x914 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS0  | 0x918 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL1  | 0x920 | 0x0000 0000 |
| OTGFS/HS_DIEPINT1  | 0x928 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ1 | 0x930 | 0x0000 0000 |
| OTGHS_DIEPDMA1     | 0x934 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS1  | 0x938 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL2  | 0x940 | 0x0000 0000 |
| OTGFS/HS_DIEPINT2  | 0x948 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ2 | 0x950 | 0x0000 0000 |
| OTGHS_DIEPDMA2     | 0x954 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS2  | 0x958 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL3  | 0x960 | 0x0000 0000 |
| OTGFS/HS_DIEPINT3  | 0x968 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ3 | 0x970 | 0x0000 0000 |
| OTGHS_DIEPDMA3     | 0x974 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS3  | 0x978 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL4  | 0x980 | 0x0000 0000 |
| OTGFS/HS_DIEPINT4  | 0x988 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ4 | 0x990 | 0x0000 0000 |
| OTGHS_DIEPDMA4     | 0x994 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS4  | 0x998 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL5  | 0x9A0 | 0x0000 0000 |
| OTGFS/HS_DIEPINT5  | 0x9A8 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ5 | 0x9B0 | 0x0000 0000 |
| OTGHS_DIEPDMA5     | 0x9B4 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS5  | 0x9B8 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL6  | 0x9C0 | 0x0000 0000 |
| OTGFS/HS_DIEPINT6  | 0x9C8 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ6 | 0x9D0 | 0x0000 0000 |
| OTGHS_DIEPDMA6     | 0x9D4 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS6  | 0x9D8 | 0x0000 0200 |
| OTGFS/HS_DIEPCTL7  | 0x9E0 | 0x0000 0000 |
| OTGFS/HS_DIEPINT7  | 0x9E8 | 0x0000 0080 |
| OTGFS/HS_DIEPTSIZ7 | 0x9F0 | 0x0000 0000 |
| OTGHS_DIEPDMA7     | 0x9F4 | 0x0000 0000 |
| OTGFS/HS_DTXFSTS7  | 0x9F8 | 0x0000 0200 |
| OTGFS/HS_DOEPCTL0  | 0xB00 | 0x0000 8000 |

|                    |       |             |
|--------------------|-------|-------------|
| OTGFS/HS_DOEPINT0  | 0xB08 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ0 | 0xB10 | 0x0000 0000 |
| OTGHS_DOEPDMA0     | 0xB14 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL1 | 0xB20 | 0x0000 0000 |
| OTGFS/HS_DOEPINT1  | 0xB28 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ1 | 0xB30 | 0x0000 0000 |
| OTGHS_DOEPDMA1     | 0xB34 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL2 | 0xB40 | 0x0000 0000 |
| OTGFS/HS_DOEPINT2  | 0xB48 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ2 | 0xB50 | 0x0000 0000 |
| OTGHS_DOEPDMA2     | 0xB54 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL3 | 0xB60 | 0x0000 0000 |
| OTGFS/HS_DOEPINT3  | 0xB68 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ3 | 0xB70 | 0x0000 0000 |
| OTGHS_DOEPDMA3     | 0xB74 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL4 | 0xB80 | 0x0000 0000 |
| OTGFS/HS_DOEPINT4  | 0xB88 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ4 | 0xB90 | 0x0000 0000 |
| OTGHS_DOEPDMA4     | 0xB94 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL5 | 0xBA0 | 0x0000 0000 |
| OTGFS/HS_DOEPINT5  | 0xBA8 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ5 | 0xBB0 | 0x0000 0000 |
| OTGHS_DOEPDMA5     | 0xBB4 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL6 | 0xBC0 | 0x0000 0000 |
| OTGFS/HS_DOEPINT6  | 0xBC8 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ6 | 0xBD0 | 0x0000 0000 |
| OTGHS_DOEPDMA6     | 0xBD4 | 0x0000 0000 |
| OTGFS/HS_DOEPCCTL7 | 0xBE0 | 0x0000 0000 |
| OTGFS/HS_DOEPINT7  | 0xBE8 | 0x0000 0000 |
| OTGFS/HS_DOEPTSIZ7 | 0xBF0 | 0x0000 0000 |
| OTGHS_DOEPDMA7     | 0xBF4 | 0x0000 0000 |
| OTGFS/HS_PCGCCTL   | 0xE00 | 0x0000 0000 |

### 21.6.3 OTGFS/HS global registers

These registers are available in both host and device modes, without the need of extra configuration when switching between two modes.

### 21.6.3.1 OTGFS/HS status and control register (OTGFS/HS\_GOTGCTL)

This register is used to control the OTG function and reflect its status.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                     |
| Bit 21     | CURMOD   | 0x0         | ro   | Current Mode of Operation<br>Accessible in both host mode and device mode<br>This bit indicates the current operation mode.<br>0: Device mode<br>1: Host mode                                                              |
| Bit 20: 17 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                     |
| Bit 16     | CONIDSTS | 0x1         | ro   | Accessible in both host mode and device mode<br>This bit reflects connector ID status<br>This bit indicates the connector ID status.<br>0: OTGFS controller is in A-device mode<br>1: OTGFS controller is in B-device mode |
| Bit 15: 0  | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                     |

### 21.6.3.2 OTGFS/HS interrupt status control register (OTGFS/HS\_GOTGINT)

The application reads this register to know about which OTG interrupt are generated, and writes this register to clear OTG interrupts.

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                                                                           |
|-----------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved  | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                |
| Bit 2     | SESENDDET | 0x0         | rw1c | Available in both host mode and device mode<br>Session end detected<br>The controller sets this bit when a Bvalid (Vbus) signal is disconnected. This register can only be set by hardware.<br>Writing 1 by software clears this bit. |
| Bit 1: 0  | Reserved  | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                |

### 21.6.3.3 OTGFS/HS AHB configuration register (OTGFS/HS\_GAHBCFG)

This register is used to configure the controller after power-on or mode change. This register mainly contains AHB-related parameters. Do not change this register after the initial configuration. The application must configure this register before starting transmission on either the AHB or USB.

| Bit       | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|-------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 9 | Reserved    | 0x000000    | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 8     | PTXFEMPLVL  | 0x0         | rw   | Accessible in host mode only<br>Periodic Tx FIFO empty level<br>It indicates when the periodic Tx FIFO empty interrupt bit in the GINTSTS register is triggered.<br>0: PTXFEMP (GINTSTS) interrupt indicates that the periodic Tx FIFO is half empty<br>1: PTXFEMP (GINTSTS) interrupt indicates that the periodic Tx FIFO is fully empty                                                                                                                                                                                     |
| Bit 7     | NPTXFEMPLVL | 0x0         | rw   | Accessible in both host mode and device mode<br>Non-Periodic Tx FIFO empty level<br>In host mode, this bit indicates when the non-periodic Tx FIFO empty interrupt (NPTXFEMP in GINTSTS) is triggered.<br>In device mode, this bit indicates when the IN endpoint Tx FIFO empty interrupt (TXFEMP bit in DIEPINTn) is triggered.<br>0: The TxFEMP (in DIEPINTn) interrupt indicates that the IN endpoint Tx FIFO is half empty<br>1: The TxFEMP (in DIEPINTn) interrupt indicates that the IN endpoint Tx FIFO is fully empty |
| Bit 6     | Reserved    | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 5     | DMAEn       | 0x0         | rw   | Accessible in master mode and device mode<br>This bit is used to enable DMA.<br>0: Slave mode<br>1: DMA mode                                                                                                                                                                                                                                                                                                                                                                                                                  |

|          |           |     |    |                                                                                                                                                                                                            |
|----------|-----------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |           |     |    | In master mode and device mode                                                                                                                                                                             |
|          |           |     |    | Burst length/type                                                                                                                                                                                          |
|          |           |     |    | 0000 :Single                                                                                                                                                                                               |
| Bit 4: 1 | HBstLen   | 0x0 | rw | 0001 :INCR4                                                                                                                                                                                                |
|          |           |     |    | 0011 :INCR8                                                                                                                                                                                                |
|          |           |     |    | 0101 :INCR16                                                                                                                                                                                               |
|          |           |     |    | Others: reserved                                                                                                                                                                                           |
|          |           |     |    | Accessible in both host mode and device mode                                                                                                                                                               |
|          |           |     |    | Global interrupt mask                                                                                                                                                                                      |
| Bit 0    | GLBINTMSK | 0x0 | rw | The application uses this bit to mask or unmask the interrupts sent by the interrupt line to itself.<br>0: Mask the interrupts sent to the application<br>1: Unmask the interrupts sent to the application |

#### 21.6.3.4 OTGFS/HS USB configuration register (OTGFS/HS\_GUSBCFG)

This register is used to configure the controller after power-on or a change to host mode or device mode. This register contains USB and USB-PHY related parameters. The application must program the register before handling any transaction on either the AHB or USB. Do not change this register after the initial configuration.

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | COTXPKT   | 0x0         | rw   | Accessible in both host mode and device mode<br>Corrupt Tx packet<br>This bit is for debug purpose only. Do not set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 30     | FDEVMODE  | 0x0         | rw   | Accessible in both host mode and device modes<br>Force device mode<br>Writing 1 to this bit forces the controller to go into device mode, irrespective of the status of the ID input point.<br>0: Normal mode<br>1: Force device mode<br>After setting this bit, the application must wait at least 25ms before the configuration takes effect.                                                                                                                                                                                                                                                                                                                                                      |
| Bit 29     | FHSTMODE  | 0x0         | rw   | Accessible in both host mode and device mode<br>Force host mode<br>Writing 1 to this bit forces the controller to go into host mode, irrespective of the status of the ID input point.<br>0: Normal mode<br>1: Force host mode<br>After setting this bit, the application must wait at least 25ms before the configuration takes effect.                                                                                                                                                                                                                                                                                                                                                             |
| Bit 28: 15 | Reserved  | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 14     | Reserved  | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 13: 10 | USBTRDTIM | 0x5         | rw   | Accessible in device mode<br>USB Turnaround Time<br>This field sets the turnaround time in PHY clocks. It defines the response time when the MAC sends a request to the packet FIFO controller (PFC) to fetch data from the DFIFO (SPRAM). These bits must be configured as follows:<br>0101: When the MAC interface is 16-bit UTMI+<br>1001: When the MAC interface is 8-bit UTMI+<br>Note: The aforementioned values are calculated based on a minimum of 30MHz AHB frequency. The USB turnaround time is critical for certifications with long cables and 5-Hub. If you want the AHB to run below 30 MHz, and don't care about the USB turnaround time, you can set larger values for these bits. |
| Bit 9: 7   | Reserved  | 0x00        | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 6      | PHYSEL    | 0x0         | rw   | Accessible in device mode only (support OTGFS)<br>OTG PHY Selection<br>OTGFS always select USB 1.1 full speed PHY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|          |          |      |      |                        |                                                                                                                                                                                                                                                                                                                                                                  |
|----------|----------|------|------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |      |      |                        | Accessible in device mode only (support OTGHS)                                                                                                                                                                                                                                                                                                                   |
|          |          |      |      |                        | OTG PHY Selection                                                                                                                                                                                                                                                                                                                                                |
|          |          |      |      |                        | 0: USB 2.0 high-speed UTMII+ PHY<br>1: Reserved, please do not use                                                                                                                                                                                                                                                                                               |
| Bit 5: 3 | Reserved | 0x00 | resd | Kept at default value. |                                                                                                                                                                                                                                                                                                                                                                  |
|          |          |      |      |                        | Accessible in both host mode and device mode                                                                                                                                                                                                                                                                                                                     |
|          |          |      |      |                        | FS/HS Timeout calibration                                                                                                                                                                                                                                                                                                                                        |
|          |          |      |      |                        | The number of PHY clocks that the application programs in these bits is added to the full-speed/high-speed interpacket timeout duration in order to compensate for any additional latency introduced by the PHY. This action can be required, because the delay triggered by the PHY while generating the line state condition can vary from one PHY to another. |
|          |          |      |      |                        | In full-speed mode, the USB standard timeout value is 16~18 (inclusive) bit times.                                                                                                                                                                                                                                                                               |
|          |          |      |      |                        | In high-speed mode, the USB standard timeout value is 736 ~ 816 (inclusive) bit times.                                                                                                                                                                                                                                                                           |
|          |          |      |      |                        | The application must program these bits according to the enumeration speed. The number of bit times added per PHY clock is as follows:                                                                                                                                                                                                                           |
|          |          |      |      |                        | High-speed mode:                                                                                                                                                                                                                                                                                                                                                 |
|          |          |      |      |                        | PHY clock (30MHz) = 16 bit times                                                                                                                                                                                                                                                                                                                                 |
|          |          |      |      |                        | PHY clock (60MHz) = 8 bit times                                                                                                                                                                                                                                                                                                                                  |
|          |          |      |      |                        | Full-speed mode:                                                                                                                                                                                                                                                                                                                                                 |
|          |          |      |      |                        | PHY clock (30MHz) = 0.4 bit times                                                                                                                                                                                                                                                                                                                                |
|          |          |      |      |                        | PHY clock (60MHz) = 0.2 bit times                                                                                                                                                                                                                                                                                                                                |
|          |          |      |      |                        | PHY clock (48MHz) = 0.25bit times                                                                                                                                                                                                                                                                                                                                |

### 21.6.3.5 OTGFS/HS reset register (OTGFS/HS\_GRSTCTL)

The application resets various hardware modules in the controller through this register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | AHBIDLE  | 0x1         | ro   | Accessible in both host mode and device modes<br>AHB master Idle<br>This bit indicates that the AHB master state machine is in idle condition.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 30: 11 | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 10: 6  | TXFNUM   | 0x00        | rw   | Accessible in both host mode and device mode<br>Tx FIFO number<br>This field indicates the FIFO number that must be refreshed through the Tx FIFO Flush bit. Do not make changes to this field until the controller clears the Tx FIFO Flush bit.<br>00000:<br>- Non-periodic Tx FIFO in host mode<br>- Tx FIFO 0 in device mode<br>00001:<br>- Periodic Tx FIFO in host mode<br>- Tx FIFO 1 in device mode<br>00010:<br>- Tx FIFO 2 in device mode<br>...<br>01111:<br>- Tx FIFO 15 in device mode<br>10000:<br>- Refresh all the transmit FIFOs in device or host mode |
| Bit 5      | TXFFLSH  | 0x0         | rw1s | Accessible in both host mode and device mode<br>Tx FIFO Flush<br>This bit selectively refreshes a single or all transmit FIFOs, but can do so when the controller is not in the process of a transaction.                                                                                                                                                                                                                                                                                                                                                                |

|       |           |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     |      | The application must write this bit only after checking that the controller is neither writing to nor reading from the TxFIFO.<br>Verify using these registers:<br>Read: NAK effective interrupt (NAK Effective Interrupt) ensures that the controller is not reading from the FIFO<br>Write: AHBIDLE bit in GRSTCTL ensures that the controller is not writing to the FIFO.<br>For FIFO reprogramming, it is usually recommended to carry out flushing operation.<br>In device endpoint disable state, it is also advised to use FIFO flushing operation. The application must wait until the controller clears this bit, before performing other operations. It takes 8 clocks to clear this bit (slowest of phy_clk or hclk)                             |
| Bit 4 | RXFFLSH   | 0x0 | rw1s | Accessible in both host mode and device mode<br>RxFIFO flush<br>The application can refresh the entire RxFIFO using this bit, but must first ensure that the controller is not in the process of a transaction. The application must only write to this bit after checking that the controller is neither reading from nor writing to the RxFIFO.<br>The application must wait until the controller clears this bit, before performing other operations. It takes 8 clocks to clear this bit (slowest of PHY or AHB)                                                                                                                                                                                                                                        |
| Bit 3 | Reserved  | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 2 | FRMCNTRST | 0x0 | rw1s | Accessible in both host mode and device mode<br>Host frame counter reset<br>The application uses this bit to reset the frame number counter inside the controller. After the frame counter is reset, the subsequent SOS sent out by the controller has a frame number of 0.<br>If the application writes 1 to this bit, it may not be able to read the value, because this bit is cleared after a few clock cycles by the controller                                                                                                                                                                                                                                                                                                                        |
| Bit 1 | PIUSFTRST | 0x0 | rw1s | Accessible in both host mode and device mode<br>PIU FS dedicated controller soft reset<br>This bit is used to reset PIU full-speed dedicated controller<br>All state machines in the PIU full-speed dedicated controller are reset to the idle state. When the PHY remains in the receive state for more than one-frame time due to PHY errors (such as operation interrupted or babble), this bit can be used to reset the PIU full-speed dedicated controller.<br>This is can be cleared automatically, the controller this clear this bit after all the necessary logic is reset in the controller.                                                                                                                                                      |
| Bit 0 | CSFTRST   | 0x0 | rw1s | Accessible in both host mode and device mode<br>Controller soft reset<br>Resets the hclk and phy_clock domain as follows:<br>Clears all interrupts and CSR registers except for the following bits:<br>- HCFG.FSLSPCS<br>- DCFG.DECSPD<br>- DCTL.SFTDIS<br>Resets all state machines (except AHB slave) to the idle state, and clears all the transmit and receive FIFOs.<br>All transactions on the AHB master are terminated as soon as possible after completing the last phase of an AHB data transfer. All transactions on the USB are terminated immediately.<br>The application can write to this bit at any time to reset the controller. This is can be cleared automatically, the controller this clear this bit after all the necessary logic is |

reset in the controller. The controller could take several clocks to clear this bit, depending on the current state of the controller. Once this bit is cleared, the application must wait at least 3 PHY clocks before accessing the PHY domain (synchronization delay).

Additionally, the application must ensure that the bit 31 in this register is set (AHB master is in idle state) before performing other operations.

Typically, the software set is used during software development and also when the user dynamically changes the PHY selection bits in the above-listed USB configuration registers. To change the PHY, the corresponding PHY clock is selected and used in the PHY domain. After a new clock is selected, the PHY domain has to be reset for normal operation.

### 21.6.3.6 OTGFS/HS interrupt register (OTGFS/HS\_GINTSTS)

This register interrupts the application due to system-level events in the current mode (device or host mode), as shown in [Figure 21-3](#).

Some of the bits in this register are available only in host mode, while others are valid in device mode only. Besides, this register indicates the current mode.

The FIFO status interrupts are read-only. The FIFO interrupt conditions are cleared automatically as soon as the software reads from or writes to the FIFO while processing these interrupts.

The application must clear the GINTSTS register at initialization before enabling an interrupt bit to avoid any interrupt generation prior to initialization.

| Bit    | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31 | WKUPINT   | 0x0         | rw1c | Accessible in both host mode and device mode<br>Resume/Remote wakeup detected interrupt<br>In device mode, this interrupt is generated only when a resume signal (triggered by host) is detected on the USB bus.<br>In host mode, this interrupt is generated only when a remote wakeup signal (triggered by device) is detected on the USB bus.                                                                                                                                                                                |
| Bit 30 | Reserved  | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 29 | DISCONINT | 0x0         | rw1c | Accessible in host mode only<br>Disconnect detected interrupt<br>The interrupt is generated when a device disconnect is detected.                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 28 | CONIDSCHG | 0x0         | rw1c | Accessible in both host mode and device modes<br>Connector ID status change<br>This bit is set by the controller when there is a change in connector ID status.                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 27 | Reserved  | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 26 | PTXFEMP   | 0x1         | ro   | Accessible in host mode only<br>Periodic Tx FIFO Empty<br>The interrupt is generated when the Periodic Transmit FIFO is either half or completely empty and there is space for a request to be written in the periodic request queue. The half or completely empty status depends on the periodic transmit FIFO empty level bit in the AHB configuration register.                                                                                                                                                              |
| Bit 25 | HCHINT    | 0x0         | ro   | Host channel interrupt<br>The controller sets this bit to indicate that an interrupt is pending on one of the channels in the controller (in host mode). The application must read the Host All Channels Interrupt register to determine the exact number of the channel on which the interrupt occurred, and then read the Host Channel-n Interrupt register to determine the interrupt event source.<br>The application must clear the corresponding status bit in the HCINTn (Host All Channels Interrupt) register to clear |

|            |                           |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|---------------------------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                           |     |      | this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 24     | PRTINT                    | 0x0 | ro   | Host port interrupt<br>The controller sets this bit to indicate a change in port status one of the ports. The application must read the Host Port Control and Status register to determine the exact event source. The application must clear the Host Port Control and Status register to clear this bit.                                                                                                                                                                                                                                                                                                            |
| Bit 23: 22 | Reserved                  | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 21     | INCOMPPIP<br>INCOMPISOOUT | 0x0 | rw1c | Incomplete periodic transfer<br>Accessible in host mode only<br>In host mode, the controller sets this interrupt bit when there are incomplete periodic transfers still pending in the current frame.<br>Incomplete Isochronous OUT Transfer<br>Accessible in device mode only<br>In device mode, the controller sets this interrupt bit to indicate that there is at least one synchronous OUT endpoint with incomplete transfers in the current frame. This interrupt is generated along with the End of Periodic Frame Interrupt bit in this register.                                                             |
| Bit 20     | INCOMPISOIN               | 0x0 | rw1c | Accessible in device mode only<br>Incomplete Isochronous IN Transfer<br>The controller sets this interrupt to indicate that there is at least one synchronous IN endpoint with incomplete transfers in the current frame. This interrupt is generated along with the End of Periodic Frame Interrupt bit in this register.                                                                                                                                                                                                                                                                                            |
| Bit 19     | OEPTINT                   | 0x0 | ro   | Accessible in device mode only<br>OUT endpoints interrupt<br>The controller sets this bit to indicate that an interrupt is pending on one of the OUT endpoints in the controller. The application must read the Device All Endpoints Interrupt register to determine the exact number of the OUT endpoint on which the interrupt occurred, and then read the corresponding Device OUT Endpoint-n Interrupt register to determine the exact source of the interrupt. The application must clear the corresponding status bit in the corresponding Device OUT Endpoint-n Interrupt register to clear this bit.          |
| Bit 18     | IEPTINT                   | 0x0 | ro   | Accessible in device mode only<br>IN Endpoints interrupt<br>The controller sets this bit to indicate that an interrupt is pending one of the IN endpoints in the controller (in device mode). The application must read the Device All Endpoints Interrupt register to determine the exact number of the IN endpoint on which the interrupt occurred, and then read the corresponding Device IN Endpoint-n Interrupt register to determine the exact source of the interrupt. The application must clear the corresponding status bit in the corresponding Device IN Endpoint-n Interrupt register to clear this bit. |
| Bit 17: 16 | Reserved                  | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 15     | EOPF                      | 0x0 | rw1c | Accessible in device mode only<br>End of periodic frame interrupt<br>This bit indicates that the period programmed in the periodic frame interval bit of the Device Configuration register has been reached in the current frame.                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 14     | ISOOUTDROP                | 0x0 | rw1c | Accessible in device mode only<br>Isochronous OUT packet dropped interrupt)<br>The controller sets this bit on the following condition: the controller fails to write a synchronous OUT packet into the receive FIFO because the receive FIFO does not have enough space to accommodate a maximum size packet for the synchronous OUT endpoint.                                                                                                                                                                                                                                                                       |

|          |            |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|------------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |            |     |      | Accessible in device mode only<br>Enumeration done                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 13   | ENUMDONE   | 0x0 | rw1c | The controller sets this bit to indicate that speed enumeration is done.<br>The application must read the Device Status register to obtain the enumeration speed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 12   | USBRST     | 0x0 | rw1c | Accessible in device mode only<br>USB Reset<br>The controller sets this bit to indicate that a reset is detected on the USB bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 11   | USBSUSP    | 0x0 | rw1c | Accessible in device mode only<br>USB Suspend<br>The controller sets this bit to indicate that a suspend is detected on the USB bus. The controller enters the Suspend state when there is no activity on the bus for a long period of time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 10   | ERLYSUSP   | 0x0 | rw1c | Accessible in device mode only<br>Early suspend<br>The controller sets this bit to indicate that the idle state has been detected on the USB bus for 3 ms.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 9: 8 | Reserved   | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 7    | GOUTNAKEFF | 0x0 | ro   | Accessible in device mode only<br>Global OUT NAK effective<br>This bit indicates that the Set Global OUT NAK bit in the Device Control register (set by the application) has taken effect. This bit can be cleared by writing the Clear Global OUT NAK bit in the Device Control register.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 6    | GINNAKEFF  | 0x0 | ro   | Accessible in device mode only<br>Global IN Non-periodic NAK effective<br>This bit indicates that the Set Global Non-periodic IN NA bit in the Device Control register (set by the application) has taken effect. That is, the controller has sampled the Global IN NAK bit set by the application. This bit can be cleared by writing the Clear Global Non-periodic IN NA bit in the Device Control register. This interrupt does not necessarily mean that a NAK handshake signal is sent out on the USB bus. The STALL bit has priority over the NAK bit.                                                                                                                                                     |
| Bit 5    | NPTXFEMP   | 0x1 | ro   | Accessible in both host and device mode<br>Non-periodic TxFIFO empty<br>This interrupt is generated when the Non-periodic TxFIFO is either half or completely empty and there is enough space for at least one request to be written to the Non-periodic Transmit Request Queue. The half or completely empty depends on the Non-periodic TxFIFO Empty Level bit in the Core AHB Configuration register.                                                                                                                                                                                                                                                                                                         |
| Bit 4    | RXFLVL     | 0x0 | ro   | Accessible in both host and device modes<br>RxFIFO Non-Empty<br>Indicates that there is at least one packet to be read from the receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 3    | SOF        | 0x0 | rw1c | Accessible in both host and device mode<br>Start of Frame<br>In host mode, the controller sets this bit to indicate that an SOF (full-speed) or Keep-Alive (low-speed) is transmitted on the USB bus. The application must set this bit to 1 to clear this interrupt.<br><br>In device mode, the controller sets this bit to indicate that an SOF token has been received on the USB bus. The application must read the Device Status register to get the current frame number. This interrupt can be generated only when the controller is running in FS mode. This bit is set by the controller. The application must write 1 to clear this bit.<br><br>Note: Reading this register immediately after power-on |

|       |         |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|---------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     |      | reset may return the value 0x1. If this register is read as 0x1 immediately after power-on reset, it does not mean that an SOF has been transmitted (in host mode) or received (in device mode). The reading of this register is valid only when an effective connection has been established between the host and the device. If this bit is set after power-on reset, the application can clear this bit.                                                                                                                                                                     |
| Bit 2 | OTGINT  | 0x0 | ro   | Accessible in both host and device mode<br>OTG interrupt<br>The controller sets this bit to indicate that an OTG protocol event is generated. The application must read the OTGFS_GOTGINT register to determine the exact source that caused this interrupt. The application must clear the corresponding status bit in the OTGFS_GOTGINT register to clear this bit.                                                                                                                                                                                                           |
| Bit 1 | MODEMIS | 0x0 | rw1c | Accessible in both host and device mode<br>Mode mismatch interrupt<br>The controller sets this bit when the application is attempting to access:<br>A host-mode register, when the controller is running in device mode<br>A device-mode register, when the controller is running in host mode<br>An OKAY response occurs when the register access is completed on the AHB, but it is ignored by the controller internally, and does not affect the operation of the controller.<br>This bit can be set by the controller only. The application must write 1 to clear this bit. |
| Bit 0 | CURMOD  | 0x0 | ro   | Accessible in both host and device modes<br>Current mode of operation<br>This bit indicates the current mode.<br>0: Device mode<br>1: Host mode                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 21.6.3.7 OTGFS/HS interrupt mask register (OTGFS/HS\_GINTMSK)

This register works with the Interrupt Register to interrupt the application. When an interrupt bit is masked, the interrupt related to this interrupt bit is not generated. However, the Interrupt Register bit corresponding to this interrupt is still set.

Interrupt mask: 0

Interrupt unmask: 1

| Bit        | Name                           | Reset value | Type | Description                                                                                                                                     |
|------------|--------------------------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | WKUPINTMSK                     | 0x0         | rw   | Accessible in both host and device modes<br>Resume/Remote wakeup detected interrupt mask                                                        |
| Bit 30     | Reserved                       | 0x0         | resd | Kept at default value.                                                                                                                          |
| Bit 29     | DISCONINTMSK                   | 0x0         | rw   | Accessible in both host and device modes<br>Disconnect detected interrupt mask                                                                  |
| Bit 28     | CONIDSCHGMSK                   | 0x0         | rw   | Accessible in both host and device modes<br>Connector ID status change mask                                                                     |
| Bit 27     | Reserved                       | 0x0         | resd | Kept at default value.                                                                                                                          |
| Bit 26     | PTXFEMPMSK                     | 0x0         | rw   | Accessible in host mode only<br>Periodic TxFIFO empty mask                                                                                      |
| Bit 25     | HCHINTMSK                      | 0x0         | rw   | Accessible in host mode only<br>Host channels interrupt mask                                                                                    |
| Bit 24     | PRTINTMSK                      | 0x0         | ro   | Accessible in host mode only<br>Host port interrupt mask                                                                                        |
| Bit 23: 22 | Reserved                       | 0x0         | resd | Kept at default value.                                                                                                                          |
| Bit 21     | INCOMPIPMSK<br>INCOMPISOOUTMSK | 0x0         | rw   | Incomplete periodic transfer mask<br>Accessible in host mode only<br>Incomplete isochronous OUT transfer mask<br>Accessible in device mode only |
| Bit 20     | INCOMISOINMSK                  | 0x0         | rw   | Accessible in device mode only<br>Incomplete isochronous IN transfer mask                                                                       |

|          |               |     |      |                                                                             |
|----------|---------------|-----|------|-----------------------------------------------------------------------------|
| Bit 19   | OEPTINTMSK    | 0x0 | rw   | Accessible in device mode only<br>OUT endpoints interrupt mask              |
| Bit 18   | IEPTINTMSK    | 0x0 | rw   | Accessible in device mode only<br>IN endpoints interrupt mask               |
| Bit 17   | Reserved      | 0x0 | rw   | Kept at default value.                                                      |
| Bit 16   | Reserved      | 0x0 | resd | Kept at default value.                                                      |
| Bit 15   | EOPFMSK       | 0x0 | rw   | Accessible in device mode only<br>End of periodic frame interrupt mask      |
| Bit 14   | ISOOUTDROPMSK | 0x0 | rw   | Device only isochronous OUT packet dropped interrupt mask                   |
| Bit 13   | ENUMDONEMSK   | 0x0 | rw   | Accessible in device mode only<br>Enumeration done mask                     |
| Bit 12   | USBRSTMSK     | 0x0 | rw   | Accessible in device mode only<br>USB Reset mask                            |
| Bit 11   | USBSUSPMSK    | 0x0 | rw   | Accessible in device mode only<br>USB suspend interrupt mask                |
| Bit 10   | ERLYSUSPMSK   | 0x0 | rw   | Accessible in device mode only<br>Early suspend interrupt mask              |
| Bit 9: 8 | Reserved      | 0x0 | resd | Kept at default value.                                                      |
| Bit 7    | GOUTNAKEFFMSK | 0x0 | rw   | Accessible in device mode only<br>Global OUT NAK effective mask             |
| Bit 6    | GINNAKEFFMSK  | 0x0 | rw   | Accessible in device mode only<br>Global Non-periodic IN NAK effective mask |
| Bit 5    | NPTXFEMPMSK   | 0x0 | rw   | Accessible in both host and device modes<br>Non-periodic TxFIFO empty mask  |
| Bit 4    | RXFLVLMSK     | 0x0 | rw   | Accessible in both host and device modes<br>Receive FIFO Non-empty mask     |
| Bit 3    | SOFMSK        | 0x0 | rw   | Accessible in both host and device modes<br>Start of Frame mask             |
| Bit 2    | OTGINTMSK     | 0x0 | rw   | Accessible in both host and device modes<br>OTG interrupt mask              |
| Bit 1    | MODEMISMSK    | 0x0 | rw   | Accessible in both host and device modes<br>Mode mismatch interrupt mask    |
| Bit 0    | Reserved      | 0x0 | resd | Kept at default value.                                                      |

### 21.6.3.8 OTGFS/HS receive status debug read/OTG status read and POP registers (OTGFS/HS\_GRXSTSR / OTGFS/HS\_GRXSTSP)

A read to the Receive Status Debug Read register returns the data of the top of the Receive FIFO. A read to the Receive Status Read and Pop register pops the data of the top of the Receive FIFO.

The receive status contents are interpreted differently in host and device modes. Then controller ignores the receive status pop/read when the receive FIFO is empty and returns the value of 0x0000 0000. The application can only pop the receive status FIFO when the receive FIFO non-empty bit of the Core Interrupt register is set.

#### Host mode:

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 21 | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                              |
| Bit 20: 17 | PKTSTS   | 0x0         | ro   | Packet status<br>Indicates the status of the received data packet.<br>0010: IN data packet received<br>0011: IN transfer completed (triggers an interrupt)<br>0101: Data toggle error (triggers an interrupt)<br>0111: Channel halted (triggers an interrupt)<br>Others: Reserved<br>Reset value: 0 |
| Bit 16: 15 | DPID     | 0x0         | ro   | Data PID<br>Indicates the data PID of the received data packet.<br>00: DATA0<br>10: DATA1<br>01: DATA2<br>11: MDATA<br>Reset value: 0                                                                                                                                                               |
| Bit 14: 4  | BCNT     | 0x000       | ro   | Byte count                                                                                                                                                                                                                                                                                          |

|          |       |     |    |                                                                                                     |
|----------|-------|-----|----|-----------------------------------------------------------------------------------------------------|
|          |       |     |    | Indicates the byte count of the received IN data packet.                                            |
| Bit 3: 0 | CHNUM | 0x0 | ro | Channel number<br>Indicates the channel number to which the currently received data packet belongs. |
|          |       |     |    |                                                                                                     |

**Device mode:**

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 25 | Reserved | 0x00        | resd | Kept at default value.                                                                                                                                                                                                                                                                                                            |
| Bit 24: 21 | FN       | 0x0         | ro   | Frame number<br>Indicates the least significant 4 bits of the frame number of the data packet received on the USB bus. This field is applicable only when the synchronous OUT endpoints are supported.                                                                                                                            |
| Bit 20: 17 | PKTSTS   | 0x0         | ro   | Packet status<br>Indicates the status of the received data packet.<br>0001: Global OUT NAK (triggers an interrupt)<br>0010: OUT data packet received<br>0011: OUT transfer completed (triggers an interrupt)<br>0100: SETUP transaction completed (triggers an interrupt)<br>0110: SETUP data packet received<br>Others: Reserved |
| Bit 16: 15 | DPID     | 0x0         | ro   | Data PID<br>Indicates the data PID of the received OUT data packet.<br>00: DATA0<br>10: DATA1<br>01: DATA2<br>11: MDATA                                                                                                                                                                                                           |
| Bit 14: 4  | BCNT     | 0x000       | ro   | Byte count<br>Indicates the byte count of the received data packet.                                                                                                                                                                                                                                                               |
| Bit 3: 0   | EPTNUM   | 0x0         | ro   | Endpoint number<br>Indicates the endpoint number to which the currently received data packet belongs.                                                                                                                                                                                                                             |

**21.6.3.9 OTGFS/HS receive FIFO size register (OTGFS/HS\_GRXFSIZ)**

The application can program the SRAM size that must be allocated to the receive FIFO.

| Bit        | Name     | Reset value | Type  | Description                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd  | Kept at default value.                                                                                                                                                                                                                                                         |
| Bit 15: 0  | RXFDEP   | 0x0200      | ro/rw | RxFIFO Depth<br>This value is in terms of 32-bit words.<br>Minimum value is 16<br>Maximum value is 512 in FS mode<br>Maximum value is 1024 in HS mode<br>The power-on reset value of this register is defined as the largest receive data FIFO depth during the configuration. |

**21.6.3.10 OTGFS/HS non-periodic Tx FIFO size****(OTGFS/HS\_GNPTXFSIZ)/Endpoint 0 Tx FIFO size registers  
(OTGFS/HS\_DIEPTXF0)**

The application can program the SRAM size and start address of the non-periodic transmit FIFO. The fields of this register varies with host mode or device mode.

**Host:**

| Bit        | Name        | Reset value | Type  | Description                                                                                                                                                        |
|------------|-------------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | NPTXFDEP    | 0x0000      | ro/rw | Non-periodic TxFIFO depth<br>This value is in terms of 32-bit words.<br>Minimum value is 16<br>Maximum value is 512 in FS mode<br>Maximum value is 1024 in HS mode |
| Bit 15: 0  | NPTXFSTADDR | 0x0200      | ro/rw | Non-periodic transmit SRAM start address                                                                                                                           |

This field contains the memory start address of the Non-periodic Transmit FIFO SRAM.

**Device:**

| Bit        | Abbr.          | Reset value | Type  | Description                                                                                                                                 |
|------------|----------------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | INEPT0TXDEP    | 0x0000      | ro/rw | N Endpoint TxFIFO 0 depth<br>This value is in terms of 32-bit words.<br>Maximum value is 512 in FS mode<br>Maximum value is 1024 in HS mode |
| Bit 15: 0  | INEPT0TXSTADDR | 0x0200      | ro/rw | IN Endpoint FIFO0 transmit SRAM start address<br>This field contains the memory start address of the IN Endpoint FIFO0 transmit SRAM.       |

### 21.6.3.11 OTGFS/HS non-periodic Tx FIFO size/request queue status register (OTGFS/HS\_GNPTXSTS)

This register is valid in host mode only. It is a read-only register that contains the available space information for the Non-periodic TxFIFO and the Non-periodic Transmit Request Queue.

| Bit        | Name          | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|---------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | Reserved      | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 30: 24 | NPTXQTOP      | 0x00        | ro   | Top of the Non-periodic transmit request queue<br>Indicates that the MAC is processing the request from the non-periodic transmit request queue.<br>Bit [30: 27]: Channel/Endpoint number<br>Bit [26: 25]:<br>00: IN/OUT token<br>01: Zero-length transmit packet (device IN/host OUT)<br>10: PING/CSPLIT token<br>11: Channel halted command<br>Bit [24]: Terminate (last request for the selected channel/endpoint) |
| Bit 23: 16 | NPTXQSPCAVAIL | 0x08        | ro   | Non-periodic transmit request queue space available<br>Indicates the amount of space available in the non-periodic transmit request queue. This queue supports both IN and OUT requests in host mode.<br>00: Non-periodic transmit request queue is full<br>01: 1 location available<br>02: 2 locations available<br>N: n locations available ( $0 \leq n \leq 8$ )<br>Others: Reserved<br>Reset value: Configurable  |
| Bit 15: 0  | NPTXFSPCAVAIL | 0x0200      | ro   | Non-periodic TxFIFO space available<br>Indicates the amount of space available in the non-periodic TxFIFO. Values are in terms of 32-bit words.<br>00: Non-periodic transmit FIFO is full<br>01: 1 location available<br>02: 2 locations available<br>N: n locations available ( $0 \leq n \leq 256$ )<br>Others: Reserved<br>Reset value: Configurable                                                               |

### 21.6.3.12 OTGFS/HS general controller configuration register (OTGFS\_GCCFG)

| Bit        | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                  |
|------------|--------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved     | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                       |
| Bit 22     | WAIT_CLK_RCV | 0x0         | rw   | Wait clksoure recover (For OTGHS mode only)<br>When the PHY is in Suspend state, after the USB is remotely woke up, the PHY is forced to wait for the stabilization of external clock until this signal is cleared.<br>After the signal is cleared, PHY needs to wait 1 ms before starting work. In Suspend handler, this bit is set to 1 by |

|            |          |        |      |                                                                                                                                                                                                                                                                                                                                  |
|------------|----------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |        |      | software. In wakeup handler, this bit is cleared by software after the current PHY clock source becomes stable.<br>0: This bit is cleared after the stabilization time of external clock<br>1: PHY is forced to wait for the stabilization time of external clock                                                                |
| Bit 21     | VBUSIG   | 0x0    | rw   | VBUS ignored<br>When this bit is set, the OTGFS controller does not monitor the Vbus pin voltage, and assumes that the Vbus is always active in both host and device modes, and leaves the Vbus pin for other purposes.<br>0: Vbus is not ignored<br>1: Vbus is ignored, and is deemed as always active                          |
| Bit 20     | SOFOUTEN | 0x0    | rw   | SOF output enable<br>0: No SOF pulse output<br>1: SOF pulse output on PIN                                                                                                                                                                                                                                                        |
| Bit 19: 18 | Reserved | 0x0    | resd | Kept at default value.                                                                                                                                                                                                                                                                                                           |
| Bit 17     | LP_MODE  | 0x0    | rw   | Low-power mode<br>This bit is used to control the OTG PHY consumption.<br>When this bit is set to 1 by software, the OTG PHY enters low-power mode; when this bit is cleared by software, the OTG PHY operates in normal mode.<br>0: Non-low-power mode<br>1: Low-power mode                                                     |
| Bit 16     | PWRDOWN  | 0x0    | rw   | Power down<br>This bit is used to activate the transceiver in transmission/reception. It must be pre-configured to allow USB communication.<br>0: Power down enable<br>1: Power down disable (Transceiver active)<br>Note: A delay of 1ms is required after power down mode is disabled to continue operating OTGHS PWRDOWN bit. |
| Bit 15: 0  | Reserved | 0x0000 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                           |

### 21.6.3.13 OTGFS/HS controller ID register (OTGFS/HS\_GUID)

This is a read-only register containing the production ID.

| Bit   | Name   | Reset value | Type | Description                                                   |
|-------|--------|-------------|------|---------------------------------------------------------------|
| 31: 0 | USERID | 0x0000 1000 | rw   | Product ID field<br>The application can program the ID field. |

### 21.6.3.14 OTGFS/HS host periodic Tx FIFO size register (OTGFS/HS\_HPTXFSIZ)

This register contains the size and memory start address of the periodic transmit FIFO.

| Bit        | Name       | Reset value | Type  | Description                                                                                                                                                                    |
|------------|------------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | PTXFSIZE   | 0x02000     | ro/rw | Host periodic TxFIFO depth<br>Values are in terms of 32-bit words.<br>Minimum value is 16<br>Maximum value is 512 in FS mode<br>Maximum value is 1024 in HS mode               |
| Bit 15: 0  | PTXFSTADDR | 0x0600      | ro/rw | Host Periodic TxFIFO start address<br>The power-on reset value of this register is the sum of the largest receive FIFO depth and the largest non-periodic transmit FIFO depth. |

### 21.6.3.15 OTGFS/HS device IN endpoint Tx FIFO size register (OTGFS/HS\_DIEPTXF $n$ ) ( $x=1\dots15$ , where $n$ is the FIFO number)

This register holds the depth and memory start address of the IN endpoint transmit FIFO in device mode. Each of the FIFOs contains an IN endpoint data. This register can be used repeatedly for instantiated IN endpoint FIFO1~15. The GNPTXFSIZ register is used to program the depth and memory start address of the IN endpoint FIFO 0.

| Bit        | Name          | Reset value | Type  | Description                                                                                                                                                                                                                               |
|------------|---------------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | INEPTXFDEP    | 0x0200      | ro/rw | IN Endpoint TxFIFO depth<br>Values are in terms of 32-bit words.<br>Minimum value is 16<br>Maximum value is 512 in FS mode<br>Maximum value is 1024 in HS mode<br>The reset value is the maximum possible IN endpoint transmit FIFO depth |
| Bit 15: 0  | INEPTXFSTADDR | 0x0400      | ro/rw | IN Endpoint FIFOOn transmit SRAM start address<br>This field contains the SRAM start address of the IN endpoint n transmit FIFO                                                                                                           |

### 21.6.4 Host-mode registers

Host-mode registers affect the operation of the controller in host mode. Host-mode register are not accessible in device mode (as the results are undefined in device mode). Host-mode registers contain as follows:

#### 21.6.4.1 OTGFS/HS host mode configuration register (OTGFS/HS\_HCFG)

This register is used to configure the controller after power-on. Do not change this register after initialization.

| Bit       | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved    | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 2     | FSLSSUPP    | 0x0         | ro   | FS- and LS-only support<br>The application uses this bit to control the controller's enumeration speed. With this bit, the application can make the controller enumerate as a full-speed host mode, even if the connected device supports high-speed communication. Do not change this bit after initial programming.<br>0: HS/FS/LS, depending on the largest speed supported by the connected device.<br>1: FS/LS-only, even if the connected device supports high-speed. |
| Bit 1: 0  | FSLSPCLKSEL | 0x0         | rw   | FS/LS PHY clock select<br>When the controller is in FS host mode:<br>01: PHY clock is running at 48MHz<br>Others: Reserved<br>When the controller is in LS host mode:<br>00: PHY clock is running at 30/60 MHz<br>01: PHY clock is running at 48 MHz<br>10: PHY clock is running at 6 MHz. If 6 MHz clock is selected, reset must be done by software.<br>11: Reserved                                                                                                      |

#### 21.6.4.2 OTGFS/HS host frame interval register (OTGFS/HS\_HFIR)

This register is used to program the frame interval for the current speed.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                |
|------------|-------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved    | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                 |
| Bit 16     | HFIIRLDCTRL | 0x0         | rw   | Reload control<br>This bit is used to disable/enable dynamic reload for the host frame register at runtime.<br>1: Reload control disable<br>0: Reload control enable<br>This bit must be configured at initialization. Do not change its value at runtime. |

---

|           |       |        |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|-------|--------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | FRINT | 0xEA60 | rw | <p>Frame interval<br/>The application uses this field to program the interval between two consecutive SOFs (full speed) or micro-SOFs (high speed) or Keep-Alive tokens.<br/>The number of PHY locks in this field indicates the frame interval. The application can write a value to the host frame interval register only after the port enable bit in the host port control and status register has been set.<br/>If no value is programmed, the controller calculates the value based on the PHY clock frequency defined in the FS/LS PHY clock select bit of the host configuration register. Do not change the value of this field after initial configuration.</p> <p>125us * (high speed PHY clock frequency)<br/>1 ms * (FS/LS PHY clock frequency)</p> |
|-----------|-------|--------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

---

#### 21.6.4.3 OTGFS/HS host frame number/frame time remaining register (OTGFS/HS\_HFNUM)

This register indicates the current frame number, and also the time remaining in the current frame (in terms of the number of PHY clocks).

| Bit        | Name  | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                       |
|------------|-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | FTREM | 0x0000      | ro   | <p>Frame time remaining<br/>Indicates the time remaining in the current frame (FS/HS/LS), in terms of the number of PHY clocks. This field decrements with the number of PHY clocks. When it reaches zero, this field is reloaded with the value of the frame interval register, and a new SOF is transmitted on the USB bus.</p> |
| Bit 15: 0  | FRNUM | 0x3FFF      | ro   | <p>Frame number<br/>This field increments every time a new SOP is transmitted on the USB bus, and is cleared to 0 when the value reaches 16'h3FFF.</p>                                                                                                                                                                            |

---

#### 21.6.4.4 OTGFS/HS host periodic Tx FIFO/request queue register (OTGFS/HS\_HPTXSTS)

This is a read-only register containing the free space information of the periodic Tx FIFO and the periodic transmit request queue.

| Bit        | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|--------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | PTXQTOP      | 0x00        | ro   | <p>Top of the periodic transmit request queue<br/>Indicates that the MAC is processing the request from the periodic transmit request queue. This register is used for debugging.</p> <p>Bit [31]: Odd/Even frame<br/>0: Transmit in even frame<br/>1: Transmit in odd frame</p> <p>Bit [30: 27]: Channel/Endpoint number</p> <p>Bit [26: 25]: Type<br/>00: IN/OUT<br/>01: Zero-length packet<br/>10: Reserved<br/>11: Channel command disable</p> <p>Bit [24]: Terminate (last request for the selected channel or endpoint)</p> |
| Bit 23: 16 | PTXQSPCAVAIL | 0x08        | ro   | <p>Periodic transmit request queue space available<br/>Indicates the number of free space available to be written in the periodic transmit request queue. This queue contains both IN and OUT requests.</p> <p>00: Periodic transmit request queue is full<br/>01: 1 space available<br/>10: 2 space available<br/>N: n space available (<math>0 \leq n \leq 8</math>)<br/>Others: Reserved</p>                                                                                                                                   |

---

---

|           |              |        |    |                                                                                                                                                                                                                                                                                                                            |
|-----------|--------------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | PTXFSPCAVAIL | 0x0100 | rw | Periodic transmit data FIFO space available<br>Indicates the number of free space available to be written in the periodic transmit FIFO, in terms of 32-bit words.<br>0000: Periodic transmit FIFO is full<br>0001: 1 space available<br>0010: 2 space available<br>N: n space available (0 ≤ n ≤ 512)<br>Others: Reserved |
|-----------|--------------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

---

#### 21.6.4.5 OTGFS/HS host all channels interrupt register (OTGFS/HS\_HINT)

When a flag event occurs on a channel, the host all channels interrupt register interrupts the application through the host channels interrupt bit of the controller interrupt register, as shown in [Figure 22-2](#). There is one interrupt bit for each channel, 16 bits in total. The application sets or clears this register by setting or clearing the appropriate bit in the corresponding host channel-n interrupt register.

| Bit        | Name     | Reset value | Type | Description                                                                            |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                                                             |
| Bit 15: 0  | HINT     | 0x0000      | ro   | Channel interrupts<br>One bit per channel: bit 0 for channel 0, bit 15 for channel 15. |

---

#### 21.6.4.6 OTGFS/HS host all channels interrupt mask register (OTGFS/HS\_HINTMSK)

The host all channels interrupt mask register works with the host all channels interrupt register to interrupt the application when an event occurs on a channel. There is one interrupt mask bit per one channel, 16 bits in total.

| Bit        | Name     | Reset value | Type | Description                                                                                |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at default value.                                                                     |
| Bit 15: 0  | HINTMSK  | 0x0000      | rw   | Channel interrupt mask<br>One bit per channel: bit 0 for channel 0, bit 15 for channel 15. |

---

#### 21.6.4.7 OTGFS/HS host port control and status register (OTGFS/HS\_HPRT)

This register is valid only in host mode. Currently, the OTG host supports only one port.

This register contains USB port-related information such as USB reset, enable, suspend, resume, connect status and test mode, as show in [Figure 22-2](#). The register of type rw1c can interrupt the application through the host port interrupt bit in the controller interrupt register. Upon a port interrupt, the application must read this register and clear the bit that caused the interrupt. For the register of type rw1c, the application must write 1 to clear the interrupt.

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                     |
|------------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 19 | Reserved  | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                          |
| Bit 18: 17 | PRTSPD    | 0x0         | ro   | Port speed<br>Indicates the speed of the device connected to this port.<br>00: High speed<br>01: Full speed<br>10: Low speed<br>11: Reserved                                                                                                                                                                                    |
| Bit 16: 13 | PRTTSTCTL | 0x0         | rw   | Port test control<br>The application writes a non-zero value to this field to put the port into test mode, and the port gives a corresponding signal.<br>0000: Test mode disabled<br>0001: Test_J mode<br>0010: Test_K mode<br>0011: Test_SE0_NAK mode<br>0100: Test_Packet mode<br>0101: Test_Force_Enable<br>Others: Reserved |
| Bit 12     | PRTPWRR   | 0x0         | rw   | Port power<br>The application uses this bit to control power supply to this port (by writing 1 or 0)<br>0: Power off                                                                                                                                                                                                            |

---

|            |             |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |     |      | 1: Power on<br>Note: This bit is not associated with interfaces. The application must follow the programming manual to set this bit for various interfaces.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 11: 10 | PRTLNSTS    | 0x0 | ro   | Port line status<br>Indicates the current logic status of the USB data lines.<br>Bit [10]: Logic level of D+<br>Bit [11]: Logic level of D-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 9      | Reserved    | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 8      | PRTRST      | 0x0 | rw   | Port reset<br>When this bit is set by the application, a reset sequence is started on this port. The application must calculate the time required for the reset sequence, and clear this bit after the reset sequence is complete.<br>0: Port not in reset<br>1: Port in reset<br>The application must keep this bit set for a minimum duration defined in Section 7.1.7.5 of USB 2.0 specification to start a reset on the port. In addition to this, the application can make this bit set for another 10 ms to the minimum duration, before clearing this bit. There is no maximum limit set by the USB standard.                                                                                                                                                     |
| Bit 7      | PRTSUSP     | 0x0 | rw1s | Port suspend<br>The application sets this bit to put this port in suspend mode. In this case, the controller only stops sending SOF. The application must set the port clock stop bit in order to disable the PHY clock.<br>The read value of this bit reflects the current suspend status of the port.<br>This bit is cleared by the controller when a remote wakeup signal is detected or when the application sets the port reset bit or port resume bit in this register, or sets the resume/remote wakeup detected interrupt bit or disconnect detected interrupt bit in the controller interrupt register.<br>The controller can still clear this bit, even if the device is disconnected with the host.<br>0: Port not in suspend mode<br>1: Port in suspend mode |
| Bit 6      | PRTRES      | 0x0 | rw   | Port resume<br>The application sets this bit to drive resume signaling on the port. The controller continues to trigger the resume signal until the application clears this bit. If the controller detects a USB remote wakeup sequence (as indicated by the port resume/remote wakeup detected interrupt bit of the controller interrupt register), the controller starts driving resume signaling without the intervention of the application.<br>The read value of this bit indicates whether the controller is currently driving resume signaling.<br>0: No resume triggered<br>1: Resume triggered                                                                                                                                                                  |
| Bit 5      | PTOVRCCCHNG | 0x0 | rw1c | Port overcurrent change<br>The controller sets this bit when the status of the port overcurrent active bit (bit 4) in this register changes. This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 4      | PTOVRCACT   | 0x0 | ro   | Port overcurrent active<br>Indicates the overcurrent status of the port.<br>0: No overcurrent<br>1: Overcurrent condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 3      | PRTENCHNG   | 0x0 | rw1c | Port enable/disable change<br>The controller sets this bit when the status of the port enable bit 2 in this register changes. This bit can only be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|       |           |     |      |                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     |      | set by the controller. The application must write 1 to clear this bit.                                                                                                                                                                                                                                                                                                                                   |
| Bit 2 | PRTENA    | 0x0 | rw1c | <p>Port enable<br/>A port is enabled only by the controller after a reset sequence. This port is enabled by an overcurrent condition, a disconnected condition or by the application.</p> <p>The application cannot set this bit by a register write operation. It can only clear this bit to disable the port. This bit does not trigger any interrupt.</p> <p>0: Port disabled<br/>1: Port enabled</p> |
| Bit 1 | PRTCNDDET | 0x0 | rw1c | <p>Port connect detected<br/>On a device connection detected, the controller sets this bit using the host port interrupt bit in the controller register. This bit can only be set by the controller. The application must write 1 to clear this bit.</p>                                                                                                                                                 |
| Bit 0 | PRTCONSTS | 0x0 | ro   | <p>Port connect status<br/>0: No device is connected to the port<br/>1: A device is connected to the port</p>                                                                                                                                                                                                                                                                                            |

#### 21.6.4.8 OTGFS/HS host channelx characteristics register (OTGFS/HS\_HCCHARx) (x = 0...15, where x= channel number)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | CHENA    | 0x0         | rw1s | <p>Channel enable<br/>This bit is set by the application and cleared by the OTG host.<br/>0: Channel disabled<br/>1: Channel enabled</p>                                                                                                                                                                                                        |
| Bit 30     | CHDIS    | 0x0         | rw1s | <p>Channel disable<br/>The application sets this bit to stop transmitting or receiving data on a channel, even before the transfer on that channel is complete. The application must wait for the generation of the channel disabled interrupt before treating the channel as disabled.</p>                                                     |
| Bit 29     | ODDFRM   | 0x0         | rw   | <p>Odd frame<br/>This bit is set / cleared by the application to indicate that the OTG host must perform a transfer in an odd frame.<br/>This bit is applicable for periodic transfers (synchronous and interrupt) only.<br/>0: Even frame<br/>1: Odd frame</p>                                                                                 |
| Bit 28: 22 | DEVADDR  | 0x00        | rw   | <p>Device address<br/>This field is used to select the device that can serve as the data source or receiver.</p>                                                                                                                                                                                                                                |
| Bit 21: 20 | MC       | 0x0         | rw   | <p>Multi count (MC)<br/>This field indicates to the host the number of transfers that must be performed per frame for the periodic endpoint.<br/>00: Reserved. This field generates undefined results.<br/>01: 1 transaction<br/>10: 2 transactions per frame<br/>11: 3 transactions per frame<br/>This field must be set to at least 0x01.</p> |
| Bit 19: 18 | EPTYPE   | 0x0         | rw   | <p>Endpoint type<br/>Indicates the transfer type selected.<br/>00: Control transfer<br/>01: Synchronous transfer<br/>10: Bulk transfer<br/>11: Interrupt transfer</p>                                                                                                                                                                           |
| Bit 17     | LSPDDEV  | 0x0         | rw   | <p>Low-speed device<br/>The application sets this bit to indicate that this channel is communicating to a low-speed device.</p>                                                                                                                                                                                                                 |
| Bit 16     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                          |

|            |        |       |    |                                                                                                     |
|------------|--------|-------|----|-----------------------------------------------------------------------------------------------------|
| Bit 15     | EPTDIR | 0x0   | rw | Endpoint direction<br>Indicates whether the transfer is in IN or OUT.<br>0: OUT<br>1: IN            |
| Bit 14: 11 | EPTNUM | 0x0   | rw | Endpoint number<br>Indicates the endpoint number on the device (serving as data source or receiver) |
| Bit 10: 0  | MPS    | 0x000 | rw | Maximum packet size<br>Indicates the maximum packet size of the corresponding port.                 |

### 21.6.4.9 OTGFS/HS host channelx split register (OTGFS/HS\_HCSPLTx) (x = 0...15, where x= channel number)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | SPLTENA  | 0x0         | rw   | Split Enable<br>This bit is set by application to indicate that this channel is enabled to perform split transactions.<br>0: Split is disabled<br>1: Split is enabled                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 30: 17 | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 16     | COMPSPLT | 0x0         | rw   | Do Complete Split<br>This bit is set by application to request the OTG host to perform a complete split transaction.<br>0: Complete split transaction is disabled<br>1: Complete split transaction is enabled                                                                                                                                                                                                                                                                                                                                       |
| Bit 15: 14 | XACTPOS  | 0x0         | rw   | Transaction Position<br>This field is used to determine whether to send all, first, middle, or last payloads with each OUT transaction.<br>11: All. This is the entire data payload of this transaction (which is less than or equal to 188 bytes)<br>10: First. This is the first data payload of this transaction (which is larger than 188 bytes)<br>00: Middle. This is the middle payload of this transaction (which is larger than 188 bytes)<br>01: Last. This is the last data payload of this transaction (which is larger than 188 bytes) |
| Bit 13: 7  | HUBADDR  | 0x00        | rw   | Hub Address<br>This field holds the hub address of the transaction translator'hub                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 6: 0   | PRTADDR  | 0x00        | rw   | Port Address<br>This field holds the endpoint number of the recipient transaction translator.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 21.6.4.10 OTGFS/HS host channelx interrupt register (OTGFS/HS\_HCINTx) (x = 0...15, where x= channel number)

This register contains the status of a channel related to USB and AHB events, as shown in [Figure 22-2](#). The application must read this register when the host channels interrupt bit is set in the controller interrupt register. Before reading this register, the application must read the host all channels interrupt register to get the exact channel number for the host channel-n interrupt register. The application must clear the corresponding bit in this register to clear the corresponding bits in the OTGFS\_HAIN and OTGFS\_GINTSTS registers.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                           |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 11 | Reserved | 0x000000    | resd | Kept at default value.                                                                                                                                                                                                                                |
| Bit 10     | DTGLERR  | 0x0         | rw1c | Data toggle error<br>This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                                                      |
| Bit 9      | FRMOVRUN | 0x0         | rw1c | Frame overrun<br>This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                                                          |
| Bit 8      | BBLERR   | 0x0         | rw1c | Babble error<br>This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                                                           |
| Bit 7      | XACTERR  | 0x0         | rw1c | Transaction error<br>Indicates one of the following errors occurred on the USB bus:<br>CRC check failure<br>Timeout<br>Bit stuffing error<br>EOP error<br>This bit can only be set by the controller. The application must write 1 to clear this bit. |
| Bit 6      | NYET     | 0x0         | rw1c | NYET Received Interrupt Response<br>This bit can only be set by the controller. It is cleared by the application writing “1”.                                                                                                                         |
| Bit 5      | ACK      | 0x0         | rw1c | ACK response received/Transmitted interrupt<br>This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                            |
| Bit 4      | NAK      | 0x0         | rw1c | NAK response received interrupt<br>This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                                        |
| Bit 3      | STALL    | 0x0         | rw1c | STALL response received interrupt<br>This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                                                      |
| Bit 2      | AHBERR   | 0x0         | rw1c | AHB Error (For OTGHS mode only)<br>This bit is set when AHB read/write error occurs in DMA mode. The application will read the corresponding DMA channel address registion to obtain error information.                                               |
| Bit 1      | CHHLTD   | 0x0         | rw1c | Channel halted<br>Indicates that the transfer completed abnormally either because of any transfer error or in response to a disable request by the application.                                                                                       |
| Bit 0      | XFERC    | 0x0         | rw1c | Transfer completed<br>Transfer completed normally, without any error. This bit can only be set by the controller. The application must write 1 to clear this bit.                                                                                     |

### 21.6.4.11 OTGFS/HS host channelx interrupt mask register (OTGFS/HS\_HCINTMSK $x$ ) ( $x = 0\ldots15$ , where $x$ = channel number)

This register is used to mask the channels described in the previous section.

| Bit        | Name        | Reset value | Type | Description                                      |
|------------|-------------|-------------|------|--------------------------------------------------|
| Bit 31: 11 | Reserved    | 0x000000    | resd | Kept at default value.                           |
| Bit 10     | DTGLERRMSK  | 0x0         | rw   | Data toggle error mask                           |
| Bit 9      | FRMOVRUNMSK | 0x0         | rw   | Frame overrun mask                               |
| Bit 8      | BBLERRMSK   | 0x0         | rw   | Babble error mask                                |
| Bit 7      | XACTERRMSK  | 0x0         | rw   | Transaction error mask                           |
| Bit 6      | NYETMSK     | 0x0         | rw   | NYET response received interrupt mask            |
| Bit 5      | ACKMSK      | 0x0         | rw   | ACK response received/transmitted interrupt mask |
| Bit 4      | NAKMSK      | 0x0         | rw   | NAK response received interrupt mask             |
| Bit 3      | STALLMSK    | 0x0         | rw   | STALL response received interrupt mask           |
| Bit 2      | AHBERRMSK   | 0x0         | rw   | AHB Error Mask (for OTGHS only)                  |
| Bit 1      | CHHLTDMSK   | 0x0         | rw   | Channel halted mask                              |
| Bit 0      | XFERCMSK    | 0x0         | rw   | Transfer completed mask                          |

### 21.6.4.12 OTGFS/HS host channelx transfer size register (OTGFS/HS\_HCTSIZ $x$ ) ( $x = 0\ldots15$ , where $x$ = channel number)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | DOPNG    | 0x0         | resd | Do Ping<br>This bit is only used for OUT transfer.<br>When this bit is set to 1, it indicates that the host implements PING protocol.<br>Note: Do not set it to 1 when IN transfer mode; otherwise, it will be disabled.                                                                                                                                                            |
| Bit 30: 29 | PID      | 0x0         | rw   | PID (Pid)<br>The application programs this field with the type of PID used for the initial transfer. The host controls this field for the rest of transfers.<br>00: DATA0<br>01: DATA2<br>10: DATA1<br>11: MDATA(non-control)/SETUP(control)                                                                                                                                        |
| Bit 28: 19 | PKTCNT   | 0x000       | rw   | Packet count<br>The application programs this field with the expected number of packets to be transmitted or received. The host decrements the packet count on every successful transmission or reception of an OUT/IN packet. When this count reaches zero, the application is interrupted to indicate normal completion of the transfer.                                          |
| Bit 18: 0  | XFERSIZE | 0x00000     | rw   | Transfer size<br>For an OUT transfer, this field indicates the number of data bytes the host sends during a transfer.<br>For an IN transfer, this field indicates the buffer size that the application has reserved for the transfer.<br>For an IN transfer (periodic and non-periodic), the application must program this field as an integer multiple of the maximum packet size. |

### 21.6.4.13 OTGHS host channel-x DMA address register (OTGHS\_HCDMA $x$ ) ( $x = 0\ldots15$ , where $x$ = channel number)

| Bit       | Name    | Reset value | Type | Description                                                                                                                                                                                                 |
|-----------|---------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | DMAADDR | 0x00000000  | rw   | DMA Address<br>This field holds the start address in the memory from which the data from the endpoint must be fetched or to which it must be stored.<br>This register is incremented on every AHB transfer. |

## 21.6.5 Device-mode registers

These registers are applicable in device mode only. They are not supported in host mode due to unknown access results. Some of the registers affect all the endpoints, while some affect only one endpoint.

### 21.6.5.1 OTGFS/HS device configuration register (OTGFS/HS\_DCFG)

This register configures the controller in device mode after power-on or after certain control commands or enumeration. Do not change this register after initial programming.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 13 | Reserved    | 0x0110      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 12: 11 | PERFRINT    | 0x0         | rw   | Periodic frame interval<br>This field indicates the time within a frame at which the periodic frame end interrupt is generated. The application can use this interrupt to determine if the synchronous transfer has been completed in a frame.<br>00: 80% of the frame interval<br>01: 85% of the frame interval<br>10: 90% of the frame interval<br>11: 95% of the frame interval                                                                                                                                                 |
| Bit 10: 4  | DEVADDR     | 0x00        | rw   | Device address<br>The application must program this field every time a SetAddress command is received.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3      | Reserved    | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 2      | NZSTSOUTSHK | 0x0         | rw   | Non-zero-length status OUT handshake<br>The application can use this field to select the handshake the controller sends on receiving a non-zero-length data packet during a control transfer' status stage.<br>1: Send a STALL handshake on a non-zero-length status OUT transfer and do not send the received OUT packet to the application<br>0: Send the received OUT packet to the application (zero-length or non-zero-length), and send a handshake based on the NAK and STALL bits in the device endpoint control register. |
| Bit 1: 0   | DEVSPD      | 0x0         | rw   | Device speed<br>This field indicates the speed at which the application needs the controller to enumerate, or the maximum speed the application can support. However, the actual bus speed is determined only after the entire sequence is complete, and is based on the speed of the USB host to which the controller is connected.<br>00: High speed<br>01: Full speed (USB2.0 PHY, clock at 30 MHz or 60 MHz)<br>10: Reserved<br>11: Full speed (USB1.1 transceiver, clock is 48MHz)                                            |

### 21.6.5.2 OTGFS/HS device control register (OTGFS/HS\_DCTL)

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                              |
|------------|-------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved    | 0x00000     | resd | Kept at default value.                                                                                                                                                                                                   |
| Bit 11     | PWRPRORGDNE | 0x0         | wo   | Power-on programming done<br>The application uses this bit to indicate that the register configuration is complete after a wakeup from power-down mode.                                                                  |
| Bit 10     | CGOUTNAK    | 0x0         | wo   | Clear global OUT NAK<br>Writing 1 to this bit clears the global OUT NAK.                                                                                                                                                 |
| Bit 9      | SGOUTNAK    | 0x0         | wo   | Set global OUT NAK<br>Writing to this bit sets the global OUT NAK.                                                                                                                                                       |
| Bit 8      | CGNPINNAK   | 0x0         | wo   | The application uses this bit to send a NAK handshake on all OUT endpoints. The application must set this bit only after checking that the global OUT NAK effective bit in the controller interrupt register is cleared. |
|            |             |             |      | Clear Global Non-periodic IN NAK<br>Writing to this bit clears the global Non-periodic OUT                                                                                                                               |

|          |             |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|-------------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |             |     |    | NAK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 7    | SGNPINNAK   | 0x0 | wo | Set global Non-periodic IN NAK<br>Writing to this bit sets the global Non-periodic OUT NAK.<br>The application uses this bit to send a NAK handshake on all non-periodic IN endpoints. The application must set this bit only after checking that the global IN NAK effective bit in the controller interrupt register is cleared.                                                                                                                                                                                         |
| Bit 6: 4 | TSTCTL      | 0x0 | rw | Test control<br>000: Test mode disabled<br>001: Test_J mode<br>010: Test_K mode<br>011: Test_SE0_NAK mode<br>100: Test_Packet mode<br>101: Test_Force_Enable<br>Others: Reserved                                                                                                                                                                                                                                                                                                                                           |
| Bit 3    | GOUTNAKSTS  | 0x0 | ro | Global OUT NAK status<br>0: A handshake is sent based on the FIFO status, NAK and STALL bit settings.<br>1: No data is written to the receive FIFO, irrespective of space availability. Sends a NAK handshake on all packets (except on SETUP transfers). Drops all synchronous OUT packets.                                                                                                                                                                                                                               |
| Bit 2    | GNPINNAKSTS | 0x0 | ro | Global Non-periodic IN NAK status<br>0: A handshake is sent based on the data status in the transmit FIFO<br>1: A NAK handshake is sent on all non-periodic IN endpoints, irrespective of the data status in the transmit FIFO.                                                                                                                                                                                                                                                                                            |
| Bit 1    | SFTDISCON   | 0x1 | rw | Software disconnect<br>The application uses this bit to indicate the OTGFS controller to perform software disconnected. Once this bit is set, the host finds the device disconnected, and the device does not receive signals on the USB bus. The controller stays in the disconnected state until the application clears this bit.<br>0: Normal operation. When this bit is cleared after a software disconnect, the controller issues a device connect event to the host. Then the USB host restarts device enumeration. |
| Bit 0    | RWKUPSIG    | 0x0 | rw | Remote wakeup signaling<br>When this bit is set by the application, the controller initiates a remote signal to wakeup the USB host. The application must set this bit to indicate the controller to exit the suspend mode. Per USB2.0 standards, the application must clear this bit 1-15 ms after setting it.                                                                                                                                                                                                            |

**Table 21-6** lists the minimum duration at which the software disconnect bit must be set in various states for the USB host to detect a device disconnect. To accommodate clock jitter, it is advised that the application adds some extra delay to the specified minimum duration.

Table 21-6 Minimum duration for software disconnect

| Operating speed | Device state                              | Minimum duration |
|-----------------|-------------------------------------------|------------------|
| Full speed      | Suspend                                   | 1ms + 2.5us      |
| Full speed      | Idle                                      | 2.5us            |
| Full speed      | No idle or suspend (performing transfers) | 2.5us            |
| High speed      | No idle or suspend (performing transfers) | 125us            |

### 21.6.5.3 OTGFS/HS device status register (OTGFS/HS\_DSTS)

This register indicates the status of the controller related to OTGFS events. It must be read on interrupt events from the device all interrupts register (OTGFS\_DAINT).

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 21: 8  | SOFFN    | 0x0000      | ro   | Frame number of the received SOF<br>Note: The read value of this field immediately after power-on reset reflects a non-zero value. If a non-zero value is returned after reading this field immediately after power-on reset, it does not mean that the host has received a SOP. The read value of this field is valid only when the host is connected to the device.                                                                                                  |
| Bit 7: 4   | Reserved | 0x1         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 3      | ETICERR  | 0x0         | ro   | Erratic error<br>This error causes the controller to enter suspend mode, and interrupt is generated with the early suspend bit of the controller interrupt register. If the early suspend is asserted due to an erratic error, the application can only perform a software disconnect recover.                                                                                                                                                                         |
| Bit 2: 1   | ENUMSPD  | 0x0         | ro   | Enumerated speed<br>Indicates the speed at which the controller has determined after speed detection through a sequence.<br>00: High speed<br>01: Full speed (PHY clock is running at 30MHz or 60MHz)<br>11: Full speed (PHY clock is running at 48MHz)<br>Others: Reserved                                                                                                                                                                                            |
| Bit 0      | SUSPSTS  | 0x0         | ro   | Suspend status<br>In device mode, this bit is set as long as a suspend condition is detected on the USB bus. The controller enters the suspend state when there is no activity on the USB bus.<br>The controller exits the suspend state on the following conditions: <ul style="list-style-type: none"><li>■ When there is an activity on the USB bus</li><li>■ When the application writes to the remote wakeup signal bit in the device control register.</li></ul> |

### 21.6.5.4 OTGFS/HS device OTGFSIN endpoint common interrupt mask register (OTGFS/HS\_DIEPMSK)

This register works with each of the device IN endpoint interrupt register for all endpoints to generate an IN endpoint interrupt. The IN endpoint interrupt for a specific status in the OTGFS\_DIEPINTx register can be masked by writing to the corresponding bit in the OTGFS\_DIEPMSK register. Status bits are masked by default.

| Bit        | Name           | Reset value | Type | Description                                                                    |
|------------|----------------|-------------|------|--------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved       | 0x000000    | resd | Kept at default value.                                                         |
| Bit 13     | NAKMSK         | 0x0         | rw   | NAK interrupt mask<br>0: NAK interrupt mask<br>1: NAK interrupt unmask         |
| Bit 12: 10 | Reserved       | 0x0         | resd | Kept at default value.                                                         |
| Bit 9      | BNAINMSK       | 0x0         | rw   | BNA interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked             |
| Bit 8      | TXFIFOUDRMSK   | 0x0         | rw   | FIFO underrun mask<br>0: Interrupt masked<br>1: Interrupt unmasked             |
| Bit 7      | Reserved       | 0x0         | resd | Kept at default value.                                                         |
| Bit 6      | INEPTNAKMSK    | 0x0         | rw   | IN endpoint NAK effective mask<br>0: Interrupt masked<br>1: Interrupt unmasked |
| Bit 5      | INTKNEPTMISMSK | 0x0         | rw   | IN token received with EP mismatch mask<br>0: Interrupt masked                 |

|       |                 |     |    |                                                                                                    |
|-------|-----------------|-----|----|----------------------------------------------------------------------------------------------------|
|       |                 |     |    | 1: Interrupt unmasked                                                                              |
| Bit 4 | INTKNTXFEMPMASK | 0x0 | rw | IN token received when TxFIFO empty mask<br>0: Interrupt masked<br>1: Interrupt unmasked           |
| Bit 3 | TIMEOUTMSK      | 0x0 | rw | Timeout condition mask (Non-isochronous endpoints)<br>0: Interrupt masked<br>1: Interrupt unmasked |
| Bit 2 | AHBERRMSK       | 0x0 | rw | AHB Error Mask (for OTGHS mode only)<br>0: AHB Error mask<br>1: AHB Error unmask                   |
| Bit 1 | EPTDISMSK       | 0x0 | rw | Endpoint disabled interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked                   |
| Bit 0 | XFERCMSK        | 0x0 | rw | Transfer completed interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked                  |

### 21.6.5.5 OTGFS/HS device OUT endpoint common interrupt mask register (OTGFS/HS\_DOEPMSK)

This register works with each of the OTGFS\_DOEPINTx registers for all endpoints to generate an OUT endpoint interrupt. Each of the bits in the OTGFS\_DOEPINTx registers can be masked by writing to the register. All interrupts are masked by default.

| Bit       | Name        | Reset value | Type | Description                                                                                                 |
|-----------|-------------|-------------|------|-------------------------------------------------------------------------------------------------------------|
| Bit 31:15 | Reserved    | 0x000000    | resd | Kept at default value.                                                                                      |
| Bit 14    | NYETMSK     | 0x0         | rw   | NYET interrupt mask<br>0: NYET interrupt masked<br>1: NYET interrupt unmasked                               |
| Bit 13    | NAKMSK      | 0x0         | rw   | NAK interrupt mask<br>0: NAK interrupt masked<br>1: NAK interrupt unmasked                                  |
| Bit 12    | BERRMSK     | 0x0         | rw   | Babble error interrupt mask<br>0: Babble error interrupt masked<br>1: Babble error interrupt unmasked       |
| Bit 11:10 | Reserved    | 0x0         | resd | Kept at default value.                                                                                      |
| Bit 9     | BNAOUTMSK   | 0x0         | rw   | BNA interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked                                          |
| Bit 8     | OUTPERRMSK  | 0x0         | rw   | OUT packet error mask<br>0: Interrupt masked<br>1: Interrupt unmasked                                       |
| Bit 7     | Reserved    | 0x0         | resd | Kept at default value.                                                                                      |
| Bit 6     | B2BSETUPMSK | 0x0         | rw   | Back-to-back SETUP packets received mask<br>0: Interrupt masked<br>1: Interrupt unmasked                    |
| Bit 5     | STSPHRCVMSK | 0x0         | rw   | Status phase receive mask (StsPhseRcvdMsk)<br>0: Interrupt masked<br>1: Interrupt unmasked                  |
| Bit 4     | OUTTEPDMSK  | 0x0         | rw   | OUT token received when endpoint disabled mask<br>0: Interrupt masked<br>1: Interrupt unmasked              |
| Bit 3     | SETUPMSK    | 0x0         | rw   | SETUP phase done mask<br>Applies to control endpoints only.<br>0: Interrupt masked<br>1: Interrupt unmasked |
| Bit 2     | AHBERRMSK   | 0x0         | rw   | AHB Error mask<br>Valid for control endpoints only.<br>0: AHB Error masked<br>1: AHB Error unmasked         |
| Bit 1     | EPTDISMSK   | 0x0         | rw   | Endpoint disabled interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked                            |
| Bit 0     | XFERCMSK    | 0x0         | rw   | Transfer completed interrupt mask<br>0: Interrupt masked                                                    |

---

 1: Interrupt unmasked
 

---

### 21.6.5.6 OTGFS/HS device all endpoints interrupt mask register (OTGFS/HS\_DAINT)

When an event occurs on an endpoint, The IN/OUT endpoint interrupt bits in the OTGS\_DAINT register can be used to interrupt the application. There is one interrupt pit per endpoint, up to 8 interrupt bits for OUT endpoints and 8 bits for IN endpoints. For a bidirectional endpoint, the corresponding IN and OUT interrupt bits are used at the same time. The corresponding bits in this register are set and cleared when the application sets and clears the bits in the corresponding device endpoint-x interrupt register.

| Bit        | Name      | Reset value | Type | Description                                                                                                    |
|------------|-----------|-------------|------|----------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved  | 0x0000      | resd | Kept at default value.                                                                                         |
| Bit 23: 16 | OUTEPTINT | 0x0000      | ro   | OUT endpoint interrupt bits<br>One OUT endpoint per bit. Bit 16 for OUT endpoint 0, bit 18 for OUT endpoint 2. |
| Bit 15: 8  | Reserved  | 0x0000      | resd | Kept at default value.                                                                                         |
| Bit 7: 0   | INEPTINT  | 0x0000      | ro   | IN endpoint interrupt bits<br>One IN endpoint per bit. Bit 0 for IN endpoint 0, bit 7 for IN endpoint 7.       |

---

### 21.6.5.7 OTGFS/HS all endpoints interrupt mask register (OTGFS/HS\_DAINTMSK)

When an event occurs on a device endpoint, the device endpoint interrupt mask register works with the device endpoint interrupt register to interrupt the application. However, the device all endpoints interrupt register corresponding to this interrupt is still set.

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                   |
|------------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved  | 0x0000      | resd | Kept at default value.                                                                                                                                        |
| Bit 23: 16 | OUTEPTMSK | 0x0000      | rw   | OUT EP interrupt mask bits<br>One OUT endpoint per bit. Bit 16 for OUT endpoint 0, bit 18 for OUT endpoint 2.<br>0: Interrupt masked<br>1: Interrupt unmasked |
| Bit 15: 8  | Reserved  | 0x0000      | resd | Kept at default value.                                                                                                                                        |
| Bit 7: 0   | INEPTMSK  | 0x0000      | rw   | IN EP interrupt mask bits<br>One IN endpoint per bit. Bit 0 for IN endpoint 0, bit 7 for IN endpoint 7.<br>0: Interrupt masked<br>1: Interrupt unmasked       |

---

### 21.6.5.8 OTGFS/HS device IN endpoint FIFO empty interrupt mask register (OTGFS/HS\_DIEPEMPMSK)

This register works with the TXFE\_OTGFS DIEPINTx register to generate an interrupt.

| Bit       | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                             |
|-----------|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved    | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                  |
| Bit 7: 0  | INEPTXFEMSK | 0x0000      | rw   | IN endpoint Tx FIFO empty interrupt mask bits<br>These bits serve as mask bits for the device IN endpoint interrupt register.<br>A transmit FIFO empty interrupt bit per IN endpoint. Bit 0 for IN endpoint 0, bit 7 for IN endpoint 7.<br>0: Interrupt masked<br>1: Interrupt unmasked |

---

### 21.6.5.9 OTGHS device all endpoints interrupt register (OTGHS\_DEACHINT)

| Bit        | Name     | Reset value | Type | Description            |
|------------|----------|-------------|------|------------------------|
| Bit 31: 18 | Reserved | 0x0000      | resd | Kept at default value  |
| Bit 17     | OEP1INT  | 0x0         | rw   | OUT EP1 interrupt      |
| Bit 16: 2  | Reserved | 0x0000      | resd | Kept at default value. |
| Bit 1      | IEP1INT  | 0x0         | rw   | IN EP1 interrupt       |
| Bit 0      | Reserved | 0x0000      | resd | Kept at default value  |

---

### 21.6.5.10 OTGHS device all endpoints interrupt register (OTGHS\_DEACHINTMSK)

| Bit        | Name       | Reset value | Type | Description            |
|------------|------------|-------------|------|------------------------|
| Bit 31: 18 | Reserved   | 0x0000      | resd | Kept at default value  |
| Bit 17     | OEP1INTMSK | 0x0         | rw   | OUT EP1 interrupt mask |
| Bit 16: 2  | Reserved   | 0x0000      | resd | Kept at default value. |
| Bit 1      | IEP1INTMSK | 0x0         | rw   | IN EP1 interrupt mask  |
| Bit 0      | Reserved   | 0x0000      | resd | Kept at default value  |

### 21.6.5.11 OTGHS device IN endpoint 1 interrupt mask register (OTGHS\_DIEPEACHMSK1)

| Bit        | Name           | Reset value | Type | Description                                                                                        |
|------------|----------------|-------------|------|----------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved       | 0x00000     | resd | Kept at default value                                                                              |
| Bit 13     | NAKMSK         | 0x0         | rw   | IN EP1 NAK mask                                                                                    |
| Bit 12: 9  | Reserved       | 0x0000      | resd | Kept at default value                                                                              |
| Bit 8      | TXFIFOUDRMSK   | 0x0         | rw   | IN EP1 txfifo underrun mask                                                                        |
| Bit 7      | Reserved       | 0x0000      | resd | Kept at default value                                                                              |
| Bit 6      | INEPTNAKMSK    | 0x0         | rw   | IN EP1 NAK effective mask)                                                                         |
| Bit 5      | INTKNEPTMISMSK | 0x0         | rw   | IN token received with EP mismatch mask)<br>0: Interrupt masked<br>1: Interrupt unmasked           |
| Bit 4      | INTKNTXFEMPMSK | 0x0         | rw   | IN token received when TxFIFO empty mask)<br>0: Interrupt masked<br>1: Interrupt unmasked          |
| Bit 3      | TIMEOUTMSK     | 0x0         | rw   | Timeout condition mask (Non-isochronous endpoints)<br>0: Interrupt masked<br>1: Interrupt unmasked |
| Bit 2      | AHBERRMSK      | 0x0         | rw   | AHB Error mask<br>For control points only.<br>0: Interrupt masked<br>1: Interrupt unmasked         |
| Bit 1      | EPTDISMSK      | 0x0         | rw   | Endpoint disabled interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked                   |
| Bit 0      | XFERCMSK       | 0x0         | rw   | Transfer completed interrupt mask<br>0: Interrupt masked<br>1: Interrupt unmasked                  |

### 21.6.5.12 OTGHS device OUT endpoint 1 interrupt mask register (OTGHS\_DOEPEACHMSK1)

| Bit        | Name       | Reset value | Type | Description                                                                           |
|------------|------------|-------------|------|---------------------------------------------------------------------------------------|
| Bit 31: 15 | Reserved   | 0x00000     | resd | Kept at default value                                                                 |
| Bit 14     | NYETMSK    | 0x0         | rw   | NYET interrupt mask<br>0: NYET interrupt is masked<br>1: NYET interrupt is not masked |
| Bit 13     | NAKMSK     | 0x0         | rw   | NAK interrupt mask<br>0: NAK interrupt is masked<br>1: NAK interrupt is not masked    |
| Bit 12     | BBLEERRMSK | 0x0         | rw   | Babble error interrupt mask<br>0: Babble error interrupt is masked                    |

|            |             |     |      |                                                                             |
|------------|-------------|-----|------|-----------------------------------------------------------------------------|
|            |             |     |      | 1: Babble error interrupt is not masked                                     |
| Bit 11: 10 | Reserved    | 0x0 | resd | Kept at default value                                                       |
|            |             |     |      | BNA interrupt mask                                                          |
| Bit 9      | BNAOUTMSK   | 0x0 | rw   | 0: Interrupt masked<br>1: Interrupt unmasked                                |
|            |             |     |      | OUT packet error mask                                                       |
| Bit 8      | OUTPERRMSK  | 0x0 | rw   | 0: Interrupt masked<br>1: Interrupt unmasked                                |
| Bit 7      | Reserved    | 0x0 | resd | Kept at default value                                                       |
|            |             |     |      | Back-to-back SETUP packets received mask                                    |
| Bit 6      | B2BSETUPMSK | 0x0 | rw   | 0: Interrupt masked<br>1: Interrupt unmasked                                |
| Bit 5      | Reserved    | 0x0 | resd | Kept at default value                                                       |
|            |             |     |      | OUT token received when endpoint disabled mask)                             |
| Bit 4      | OUTTEPDMSK  | 0x0 | rw   | 0: Interrupt masked<br>1: Interrupt unmasked                                |
|            |             |     |      | SETUP phase done mask                                                       |
| Bit 3      | SETUPMSK    | 0x0 | rw   | For control endpoints only.<br>0: Interrupt masked<br>1: Interrupt unmasked |
|            |             |     |      | AHB Error mask                                                              |
| Bit 2      | AHBERRMSK   | 0x0 | rw   | For control endpoints only.<br>0: Interrupt masked<br>1: Interrupt unmasked |
|            |             |     |      | Endpoint disabled interrupt mask                                            |
| Bit 1      | EPTDISMSK   | 0x0 | rw   | 0: Interrupt masked<br>1: Interrupt unmasked                                |
|            |             |     |      | Transfer completed interrupt mask                                           |
| Bit 0      | XFERCMSK    | 0x0 | rw   | 0: Interrupt masked<br>1: Interrupt unmasked                                |

### 21.6.5.13 OTGFS/HS device control IN endpoint 0 control register (OTGFS/HS\_DIEPCTL0)

This section describes the control IN endpoint 0 control register. Nonzero control endpoint uses registers for endpoints 1-7.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | EPTENA   | 0x0         | rw1s | Endpoint enable<br>The application sets this bit to start data transmission on the endpoint 0.<br>The controller clears this bit before generating the following interrupts:<br>– Endpoint disabled<br>– Transfer completed.                                                                                                                                                                                                                                                  |
| Bit 30     | EPTDIS   | 0x0         | ro   | Endpoint disable<br>The application sets this bit to stop data transmission on an endpoint. The application must wait for the endpoint disabled interrupt before treating the endpoint as disabled. The controller clears this bit before setting the endpoint disabled interrupt. The application must set this bit only when the endpoint is enabled.                                                                                                                       |
| Bit 29: 28 | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 27     | SNAK     | 0x0         | wo   | Set NAK<br>A write to this bit sets the NAK bit of the endpoint. The application can use this bit to control the transmission of NAK handshakes on the endpoint. The controller also sets this bit when a SETUP data packet is received on the endpoint.                                                                                                                                                                                                                      |
| Bit 26     | CNAK     | 0x0         | wo   | Clear NAK<br>A write to this bit clears the NAK bit for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 25: 22 | TXFNUM   | 0x0         | rw   | TxFIFO number<br>The endpoint 0 can only use FIFO0.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 21     | STALL    | 0x0         | rw1s | STALL handshake<br>The application sets this bit, and the controller clears this bit when a SETUP token is received. If a NAK bit, a global non-periodic IN NAK or global OUT NAK bit is set along with this bit, the STALL bit has priority.                                                                                                                                                                                                                                 |
| Bit 20     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 19: 18 | EPTYPE   | 0x0         | ro   | Endpoint type<br>Set to 0 by hardware for control endpoints.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 17     | NAKSTS   | 0x0         | ro   | NAK status<br>Indicates the following:<br>0: The controller is transmitting non-NAK handshakes based on the FIFO status<br>1: The controller is transmitting NAK handshakes on this endpoint<br>When this bit is set, either by the application or controller, the controller stops transmitting data, even if there are space available in the receive FIFO. The controller always responds to SETUP data packets with an ACK handshake, irrespective of this bit's setting. |
| Bit 16     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 15     | USBACEPT | 0x1         | ro   | USB active endpoint<br>This bit is always set to 1, indicating that the control endpoint 0 is always active in all configurations and interfaces.                                                                                                                                                                                                                                                                                                                             |
| Bit 14: 2  | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 1: 0   | MPS      | 0x0         | rw   | Applies to IN and OUT endpoints<br>The application uses this bit to program the maximum packet size for the current logical endpoint.<br>00: 64 bytes<br>01: 32 bytes<br>10: 16 bytes<br>11: 8 bytes                                                                                                                                                                                                                                                                          |

### 21.6.5.14 OTGFS/HS device IN endpoint-x control register (OTGFS/HS\_DIEPCTLx) (x=1...7, where x is endpoint number)

The application uses this register to control the behavior of the endpoints other than endpoint 0.

| Bit        | Name                   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|------------------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | EPTENA                 | 0x0         | rw1s | <p>Endpoint enable</p> <p>The application sets this bit to start transmitting data on an endpoint. The controller clears this bit before the generation one of the following interrupts on this endpoint:</p> <ul style="list-style-type: none"> <li>- SETUP stage done</li> <li>- Endpoint disabled</li> <li>- Transfer completed</li> </ul>                                                                                   |
| Bit 30     | EPTDIS                 | 0x0         | rw1s | <p>Endpoint disable</p> <p>The application sets this bit to stop transmitting data on an endpoint, even if the transfer on that endpoint is incomplete.</p> <p>The application must wait for the endpoint disabled interrupt before treating the endpoint as disabled. The controller clears this bit before setting the endpoint disabled interrupt. The application must set this bit only when the endpoint enabled set.</p> |
| Bit 29     | SETD1PID/<br>SETODDFR  | 0x0         | wo   | <p>Set DATA1 PID</p> <p>Applies to interrupt/bulk IN endpoints only. Writing to this bit sets the endpoint data PID bit in this register to DATA1.</p> <p>Set odd frame</p> <p>Applies to synchronous IN endpoints only. Writing to this bit sets the Even/Odd frame to odd frame.</p> <p>0: Disabled Set DATA1 PID disabled or Do not force odd frame<br/>1: Set DATA1 PID enabled or forced odd frame</p>                     |
| Bit 28     | SETD0PID/<br>SETEVENFR | 0x0         | rw   | <p>Set DATA0 PID</p> <p>Applies to interrupt/bulk IN endpoints only. Writing to this bit sets the endpoint data PID bit in this register to DATA0.</p> <p>Set Even frame</p> <p>Applies to synchronous IN endpoints only. Writing to this bit sets the Even/Odd frame to even frame.</p> <p>0: Disabled Set DATA0 PID disabled or Do not force even frame<br/>1: Set DATA0PID or set the EOFRNUM to even frame</p>              |
| Bit 27     | SNAK                   | 0x0         | wo   | <p>Set NAK</p> <p>A write to this bit sets the NAK bit for the endpoint. The application uses this bit to control the transmission of NAK handshakes on an endpoint. The controller sets this bit on a Transfer completed interrupt or after receiving a SETUP packet.</p> <p>Values:</p> <p>0: Do not set NAK<br/>1: Set NAK</p>                                                                                               |
| Bit 26     | CNAK                   | 0x0         | wo   | <p>Clear NAK</p> <p>A write to this bit clears the NAK bit for this endpoint.</p> <p>0: Not clear NAK<br/>1: Clear NAK</p>                                                                                                                                                                                                                                                                                                      |
| Bit 25: 22 | TXFNUM                 | 0x0         | rw   | <p>TxFIFO number</p> <p>Allocate FIFO number to the corresponding endpoint. A separate FIFO number is allocated to each valid IN endpoint. This bit applies to IN endpoints only.</p>                                                                                                                                                                                                                                           |
| Bit 21     | STALL                  | 0x0         | rw   | <p>STALL handshake</p> <p>Applies to non-control, non-synchronous IN and OUT endpoints.</p> <p>The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, global non-</p>                                                                                                                                                                                                              |

|            |                  |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|------------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                  |       |      | periodic IN NAK bit or global OUT NAK bit is set along with this bit, the STALL bit has priority. Only the application can clear this bit, but the controller never.<br>0: Stall all invalid tokens<br>1: Stall all valid tokens                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 20     | Reserved         | 0x0   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 19: 18 | EPTYPE           | 0x0   | rw   | Endpoint type<br>This is the transfer type supported by this logical endpoint.<br>00: Control<br>01: Synchronous<br>10: Bulk<br>11: Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 17     | NAKSTS           | 0x0   | ro   | NAK status<br>Indicates the following status:<br>0: The controller is sending non-NAK handshakes based on the FIFO status<br>1: The controller is sending NAK handshakes<br>When this bit is set (either by the application or the controller), <ul style="list-style-type: none"><li>- The controller stops receiving any data on an OUT endpoint, even if there is space in the receive FIFO to accommodate the incoming data packets.</li><li>- For non-synchronous IN endpoints: the controller stops transmitting data on the endpoint, even if there is data pending in the transmit FIFO.</li><li>- For synchronous IN endpoints: the controller sends a zero-length data packet, even if there is space in the transmit FIFO.</li></ul> The controller always responds to SETUP data packets with an ACK handshake, regardless of whether this bit is set or not. |
| Bit 16     | DPID/<br>EOFRNUM | 0x0   | ro   | Endpoint data PID<br>Applies to interrupt/bulk IN endpoints only.<br>This bit contains the PID of the packet to be transmitted on this endpoint. The application must program the PID of the initial data packet to be received or transmitted on this endpoint, after the endpoint is enabled. The application programs DATA0 or DATA1 PID through the SetD1PID and SetD0PID of this register.<br>0: DATA0<br>1: DATA1<br>Even/Odd frame<br>Applies to synchronous IN endpoints only.<br>Indicates the frame number in which the controller transmits synchronous data on this endpoint. The application must program the even/odd frame number in which it tends to transmit or receive synchronous data through the SETEVNFR and SETODDFR bits in this register.<br>0: Even frame<br>1: Odd frame                                                                      |
| Bit 15     | USBACEPT         | 0x0   | rw   | USB active endpoint<br>Indicates whether this endpoint is active in the current configuration and interface. The controller clears this bit for all endpoints except for endpoint 0 after detecting a USB reset. After receiving the SetConfiguration and SetInterface commands, the application must program the endpoint registers and set this bit.<br>0: Inactive<br>1: Active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 14: 11 | Reserved         | 0x0   | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 10: 0  | MPS              | 0x000 | rw   | Maximum packet size<br>The application uses this field to set the maximum packet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

size for the current logical endpoint. The values are in bytes.

### 21.6.5.15 OTGFS/HS device control OUT endpoint 0 control register (OTGFS/HS\_DOEPCTL0)

This section describes the control OUT endpoint 0 control register. Non-zero control endpoints use registers for endpoints 1-7.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | EPTENA   | 0x0         | rw1s | Endpoint enable<br>The application sets this bit to start transmitting data on endpoint 0. The controller clears this bit before setting any one of the following interrupts on this endpoint:<br>– SETUP stage done<br>– Endpoint disabled<br>– Transfer completed                                                                                                                                                                                                        |
| Bit 30     | EPTDIS   | 0x0         | ro   | Endpoint disable<br>The application cannot disable control OUT endpoint 0.                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 29: 28 | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 27     | SNAK     | 0x0         | wo   | Set NAK<br>A write to this bit sets the NAK bit for this endpoint. The application can use this bit to control the transmission of NAK handshakes on an endpoint. The controller sets this bit on a transfer completed interrupt or when a SETUP data packet is received.                                                                                                                                                                                                  |
| Bit 26     | CNAK     | 0x0         | wo   | Clear NAK<br>A write to this bit clears the NAK for the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 25: 22 | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 21     | STALL    | 0x0         | rw1s | STALL handshake<br>The application sets this bit and the controller clears this bit when a SETUP token is received for this endpoint. If a NAK bit, global non-periodic OIT NAK bit is set along with this bit, the STALL bit has priority. The controller always responds to SETUP data packets, regardless of whether this bit is set or not.                                                                                                                            |
| Bit 20     | SNP      | 0x0         | rw   | Snoop mode<br>This bit configures the endpoint to Snoop mode. In this mode, the controller does not check the correctness of OUT packets before transmitting OUT packets to the application memory.                                                                                                                                                                                                                                                                        |
| Bit 19: 18 | EPTYPE   | 0x0         | ro   | Endpoint type<br>Hardware sets this bit to 0 to control endpoint type.                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 17     | NAKSTS   | 0x0         | ro   | NAK status<br>Indicates the following:<br>0: The controller is sending non-NAK handshakes based on the FIFO status<br>1: The controller is sending NAK handshakes<br>When this bit is set (either by the application or the controller), the controller stops receiving any data on an OUT endpoint, even if there is space in the receive FIFO. The controller always responds to SETUP data packets with an ACK handshake, regardless of whether this bit is set or not. |
| Bit 16     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 15     | USBACEPT | 0x1         | ro   | USB active endpoint<br>This bit is always set to 1, indicating that a control endpoint 0 is always active in all configurations and interfaces.                                                                                                                                                                                                                                                                                                                            |
| Bit 14: 2  | Reserved | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 1: 0   | MPS      | 0x0         | ro   | Maximum packet size<br>The maximum packet size of the control OUT endpoint 0 is the same as that of the control IN endpoint 0.<br>00: 64 bytes<br>01: 32 bytes                                                                                                                                                                                                                                                                                                             |

10: 16 bytes  
11: 8 bytes

### 21.6.5.16 OTGFS/HS device control OUT endpoint-x control register (OTGFS/HS\_DOEPCCTLx) (x=1...7, where x if endpoint number)

This application uses this register to control the behavior of all endpoints other than endpoint 0.

| Bit        | Name                   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|------------------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | EPTENA                 | 0x0         | rw1s | <p>Endpoint enable<br/>Indicates that the descriptor structure and data buffer for data reception has been configured. The controller clears this bit before setting any one of the following interrupts on this endpoint:</p> <ul style="list-style-type: none"> <li>- SETUP stage done</li> <li>- Endpoint disabled</li> <li>- Transfer completed</li> </ul>                                                                                                         |
| Bit 30     | EPTDIS                 | 0x0         | ro   | <p>Endpoint disable<br/>The application sets this bit to stop transmitting data on an endpoint, even if the transfer on that endpoint is incomplete.<br/>The application must wait for the endpoint disabled interrupt before treating the endpoint as disabled. The controller clears this bit before setting the endpoint disabled interrupt. The application must set this bit only when the endpoint enabled set.</p> <p>0: No effect<br/>1: Endpoint disabled</p> |
| Bit 29     | SETD1PID/<br>SETODDFR  | 0x0         | rw   | <p>Set DATA1 PID<br/>Applies to interrupt/bulk OUT endpoints only. Writing to this bit sets the endpoint data PID bit in this register to DATA1.</p> <p>Set odd frame<br/>Applies to synchronous OUT endpoints only. Writing to this bit sets the Even/Odd frame to odd frame.</p> <p>0: Disabled Set DATA1 PID disabled or Do not force odd frame<br/>1: Set DATA1 PID enabled or forced odd frame</p>                                                                |
| Bit 28     | SETD0PID/<br>SETEVENFR | 0x0         | rw   | <p>Set DATA0 PID<br/>Applies to interrupt/bulk OUT endpoints only. Writing to this bit sets the endpoint data PID bit in this register to DATA0.</p> <p>Set Even frame<br/>Applies to synchronous OUT endpoints only. Writing to this bit sets the Even/Odd frame to even frame.</p> <p>0: Disabled Set DATA0 PID disabled or Do not force even frame<br/>1: Set DATA0PID or set the EOFRNUM to even frame</p>                                                         |
| Bit 27     | SNAK                   | 0x0         | wo   | <p>Set NAK<br/>A write to this bit sets the NAK bit for the endpoint. The application uses this bit to control the transmission of NAK handshakes on an endpoint. The controller sets this bit on a Transfer completed interrupt or after receiving a SETUP packet.</p> <p>Values:<br/>0: Do not set NAK<br/>1: Set NAK</p>                                                                                                                                            |
| Bit 26     | CNAK                   | 0x0         | wo   | <p>Clear NAK<br/>A write to this bit clears the NAK bit for the endpoint.</p> <p>0: Not clear NAK<br/>1: Clear NAK</p>                                                                                                                                                                                                                                                                                                                                                 |
| Bit 25: 22 | Reserved               | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 21     | STALL                  | 0x0         | rw   | <p>Applies to non-control, non-synchronous IN and OUT endpoints.<br/>The application sets this bit to stall all tokens from the</p>                                                                                                                                                                                                                                                                                                                                    |

|            |                  |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|------------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                  |     |      | USB host to this endpoint. If a NAK bit , global non-periodic IN NAK bit or global OUT NAK bit is set along with this bit, the STALL bit has priority. Only the application can clear this bit, but the controller never.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 20     | SNP              | 0x0 | rw   | Snoop mode<br>This bit configures the endpoint to Snoop mode. In this mode, the controller does not check the correctness of OUT packets before transmitting OUT packets to the application memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 19: 18 | EPTYPE           | 0x0 | rw   | Endpoint type<br>This is the transfer type supported by this logical endpoint.<br>00: Control<br>01: Synchronous<br>10: Bulk<br>11: Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 17     | NAKSTS           | 0x0 | ro   | NAK status<br>Indicates the following:<br>0: The controller is sending non-NAK handshakes based on the FIFO status<br>1: The controller is sending NAK handshakes<br>When this bit is set (either by the application or the controller),<br>– The controller stops receiving any data on an OUT endpoint, even if there is space in the receive FIFO to accommodate the incoming data packets.<br>– For non-synchronous IN endpoints: the controller stops transmitting data on the endpoint, even if there is data pending in the transmit FIFO.<br>– For synchronous IN endpoints: the controller sends a zero-length data packet, even if there is space in the transmit FIFO.<br>The controller always responds to SETUP data packets with an ACK handshake, regardless of whether this bit is set or not. |
| Bit 16     | DPID/<br>EOFRNUM | 0x0 | ro   | Endpoint data PID<br>Applies to interrupt/bulk OUT endpoints only.<br>This bit contains the PID of the packet to be transmitted on this endpoint. The application must program the PID of the initial data packet to be received or transmitted on this endpoint, after the endpoint is enabled. The application programs DATA0 or DATA1 PID through the SetD1PID and SetD0PID of this register.<br>0: DATA0<br>1: DATA1<br>Even/Odd frame<br>Applies to synchronous OUT endpoints only.<br>Indicates the frame number in which the controller transmits synchronous data on this endpoint. The application must program the even/odd frame number in which it tends to transmit or receive synchronous data through the SETEVNFR and SETODDFR bits in this register.<br>0: Even frame<br>1: Odd frame         |
| Bit 15     | USBACEPT         | 0x0 | rw   | USB active endpoint<br>Indicates whether this endpoint is active in the current configuration and interface. The controller clears this bit for all endpoints except for endpoint 0 after detecting a USB reset. After receiving the SetConfiguration and SetInterface commands, the application must program the endpoint registers and set this bit.<br>0: Inactive<br>1: Active                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 14: 11 | Reserved         | 0x0 | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|           |     |       |    |                                                                                                                                                  |
|-----------|-----|-------|----|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 10: 0 | MPS | 0x000 | rw | Maximum packet size<br>The application uses this field to set the maximum packet size for the current logical endpoint. The values are in bytes. |
|-----------|-----|-------|----|--------------------------------------------------------------------------------------------------------------------------------------------------|

### 21.6.5.17 OTGFS/HS device IN endpoint-x interrupt register (OTGFS\_DIEPINTx) (x=0...7, where x if endpoint number)

This register indicates the status of an endpoint when USB and AHB-related events occurs, as shown in [Figure 21-3](#). When the IEPINT bit of the OTGFS/HS\_GINTSTS register is set, the application must first read the OTGFS\_DAINT register to get the exact endpoint number in which the event occurs, before reading the endpoint interrupt registers. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTGFS/HS\_DAINT and OTGFS/HS\_GINTST registers.

| Bit       | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|-------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved    | 0x000000    | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 7     | TXFEMP      | 0x0         | ro   | Transmit FIFO empty<br>This interrupt is generated when the transmit FIFO for this endpoint is half or completely empty. The half or completely empty status depends on the transmit FIFO empty level bit in the controller AHB configuration register.                                                                                                                                                          |
| Bit 6     | INEPTNAK    | 0x0         | rw1c | IN endpoint NAK effective<br>This bit can be cleared by writing 1 to the CNAK bit in the DIEPCTLx register.<br>This interrupt indicates that the IN endpoint NAB bit set by the application has taken effect.<br>This interrupt does not guarantee that a NAK handshake is sent on the USB line. A STALL bit has priority over a NAK bit.<br>This bit applies to the scenario only when the endpoint is enabled. |
| Bit 5     | Reserved    | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 4     | INTKNTXFEMP | 0x0         | rw1c | N token received when TxFIFO is empty<br>Indicates that an IN token was received when the associated transmit FIFO (periodic or non-periodic) was empty. An interrupt is generated on the endpoint for which an IN token was received.                                                                                                                                                                           |
| Bit 3     | TIMEOUT     | 0x0         | rw1c | Timeout condition<br>Applies to control IN endpoints only. This bit indicates that the controller has detected a timeout condition for the last IN token on this endpoint.                                                                                                                                                                                                                                       |
| Bit 2     | AHBERR      | 0x0         | rw1c | AHB Error (For OTGHS mode only)<br>This bit is set when AHB read/write error occurs in DMA mode. The application reads the corresponding DMA channel address register to obtain error information.                                                                                                                                                                                                               |
| Bit 1     | EPTDISD     | 0x0         | rw1c | Endpoint disabled interrupt<br>This bit indicates that the endpoint is disabled according to the application's request.                                                                                                                                                                                                                                                                                          |
| Bit 0     | XFERC       | 0x0         | rw1c | Transfer completed interrupt<br>Indicates that the programmed transfers are complete on the AHB and on the USB for this endpoint.                                                                                                                                                                                                                                                                                |

### 21.6.5.18 OTGFS/HS device OUT endpoint-x interrupt register (OTGFS/HS\_DOEPINTx) (x=0...7, where x if endpoint number)

This register indicates the status of an endpoint with respect to USB and AHB-related events, as shown in [Figure 21-3](#). When the OEPINT bit of the OTGFS/HS\_GINTSTS register is set, the application must first read the OTGFS\_DAINT register to get the exact endpoint number in which the event occurs, before reading the endpoint interrupt registers. The application must clear the appropriate bit in this register to clear the corresponding bits in the OTGFS/HS\_DAINT and OTGFS/HS\_GINTST registers.

| Bit        | Name       | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved   | 0x00000     | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 15     | STPPKRX    | 0x0         | rw1c | Setup packet received (For OTGHS only)<br>Applicable for control OUT endpoints in only the Buffer DMA mode.<br>This bit is set by the OTGHS to indicate that this buffer holds 8 bytes of set up data. There is only one setup packet per buffer. On receiving a setup packet, the OTGHS closes the buffer and disables the corresponding endpoint. The application must then re-enable the endpoint to receive any OUT data for the control transfer and re-program the buffer start address. Because of the above behavior, OTGHS can receive any number of back to back setup packets and one buffer for every setup packet is used. |
| Bit 14     | NYETINTRPT | 0x0         | rw1c | NYET interrupt<br>This interrupt is generated when a NYET response is transmitted for a nonisochronous OUT endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 13     | NAKINTRPT  | 0x0         | rw1c | NAK interrupt<br>This interrupt is generated when a NAK is transmitted or received by the device. In case of isochronous IN endpoints the interrupt gets generated when a zero length packet is transmitted due to unavailability of data in the TXFIFO.                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 12: 7  | Reserved   | 0x00        | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 6      | B2BSTUP    | 0x0         | rw1c | Back-to-back SETUP packets received<br>Indicates that more than three back-to-back SETUP packets are received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 5      | STSPCVD    | 0x0         | rw1c | Status phase received for control write (for OTGHS only)<br>This interrupt is valid only for control OUT endpoints.<br>This interrupt is generated only after OTGHS has transferred all the data that the host has sent during the data phase of a control write transfer, to the system memory buffer. The interrupt indicates to the application that the host has switched from data phrase to the status phase of a control transfer. The application can use this interrupt to ACK or STALL the status phase, after it has decoded the data phase.                                                                                 |
| Bit 4      | OUTTEPD    | 0x0         | rw1c | OUT token received when endpoint disabled<br>Applies to control OUT endpoints only.<br>Indicates that an OUT token was received when the endpoint has not yet been enabled. An interrupt is generated on the endpoint for which an OUT token was received.                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 3      | SETUP      | 0x0         | rw1c | SETUP phase done<br>Applies to control OUT endpoints only.<br>Indicates that the SETUP stage for the control endpoint is complete and no more back-to-back SETUP packets were received for the current control transfer. Upon this interrupt, the application can decode the received SETUP data packets.                                                                                                                                                                                                                                                                                                                               |
| Bit 2      | AHBERR     | 0x0         | rw1c | AHB Error (For OTGHS mode only)<br>This bit is set when AHB read/write error occurs in DMA mode. The application reads the corresponding DMA channel address register to obtain error information.                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|       |         |     |      |                                                                                                                                   |
|-------|---------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 1 | EPTDISD | 0x0 | rw1c | Endpoint disabled interrupt<br>Indicates that the endpoint is disabled according to the application's request.                    |
| Bit 0 | XFERC   | 0x0 | rw1c | Transfer completed interrupt<br>Indicates that the programmed transfers are complete on the AHB and on the USB for this endpoint. |

### 21.6.5.19 OTGFS/HS device IN endpoint 0 transfer size register (OTGFS/HS\_DIEPTSIZE0)

The application must set this register before enabling endpoint 0. Once the endpoint 0 is enabled using the endpoint enable pin in the device endpoint 0 control register, the controller modifies this register. The application can only read this register as long as the controller clears the endpoint enable bit.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 21 | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                              |
| Bit 20: 19 | PKTCNT   | 0x0         | rw   | Packet count<br>Indicates the total number of USB packets that constitute the transfer size of data for the endpoint 0.<br>This field is decremented every time a packet is read from the transmit FIFO (maximum packet size or short packet)                                                                                                                                       |
| Bit 18: 7  | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                              |
| Bit 6: 0   | XFERSIZE | 0x00        | rw   | Transfer size<br>Indicates the transfer size (in bytes) for the endpoint 0.<br>The controller interrupts the application when the transfer size becomes 0. The transfer size can be set to the maximum packet size of the endpoint at the end of each packet.<br>The controller decrements this field every time a packet from the external memory is written to the transmit FIFO. |

### 21.6.5.20 OTGFS/HS device OUT endpoint 0 transfer size register (OTGFS/HS\_DOEPTSIZE0)

The application must set this register before enabling endpoint 0. Once the endpoint 0 is enabled using the endpoint enable pin in the device endpoint 0 control register, the controller modifies this register. The application can only read this register as long as the controller clears the endpoint enable bit.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 30: 29 | SUPCNT   | 0x0         | rw   | SETUP packet count<br>Indicates the number of back-to-back SETUP data packets the endpoint can receive.<br>01: 1 packet<br>10: 2 packets<br>11: 3 packets                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 28: 20 | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 19     | PKTCNT   | 0           | rw   | Packet count<br>This bit is decremented to 0 after a packet is written to the receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 18: 7  | Reserved | 0x000       | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 6: 0   | XFERSIZE | 0x00        | rw   | Transfer size<br>Indicates the transfer size (in bytes) for the endpoint 0.<br>The controller interrupts the application when the transfer size becomes 0. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.<br>The controller decrements this field every time a packet from the external memory is written to the transmit FIFO.<br>The controller decrements this field every time a packet from the receive FIFO is written to the external memory. |

### 21.6.5.21 OTGFS/HS device IN endpoint-x transfer size register (OTGFS/HS\_DIEPTSI<sub>x</sub>) (x=1...7, where x is endpoint number)

The application must set this register before enabling endpoint x. Once the endpoint x is enabled using the endpoint enable pin in the device endpoint x control register, the controller modifies this register. The application can only read this register as long as the controller clears the endpoint enable bit.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 30: 29 | MC       | 0x0         | rw   | Multi count<br>For periodic IN endpoints, this field indicates the number of packets to be transmitted on the USB for each frame.<br>The controller uses this field to calculate the data PID transmitted on synchronous IN endpoints.<br>01: 1 packet<br>10: 2 packets<br>11: 3 packets                                                                                                                  |
| Bit 28: 19 | PKTCNT   | 0x000       | rw   | Packet count<br>Indicates the total number of USB packets (data transfer size on the endpoint) this field is decremented every time a packet is read from the transmit FIFO (maximum packet size and short packet).                                                                                                                                                                                       |
| Bit 18: 0  | XFERSIZE | 0x00000     | rw   | Transfer Size<br>Indicates the transfer size (in bytes) for the current endpoint. The controller interrupts the application when the transfer size becomes 0. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.<br>The controller decrements this field every time a packet from the external memory is written to the transmit FIFO. |

### 21.6.5.22 OTGHS device IN endpoint-x DMA address register (OTGHS\_DIEPDMA<sub>x</sub>) (x=1...7, where x is endpoint number)

| Bit       | Name    | Reset value | Type | Description                                                                                                                                                                                                                   |
|-----------|---------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | DMAADDR | 0x00000000  | rw   | DMA Address<br>This bit holds the start address of the external memory for storing or fetching endpoint data.<br>Note: This register is incremented on every AHB transaction. The application must set words-aligned address. |

### 21.6.5.23 OTGFS/HS device IN endpoint transmit FIFO status register (OTGFS/HS\_DTXFSTS<sub>x</sub>) (x=1...7, where x is endpoint number)

This is a read-only register containing the free space information for device IN endpoint transmit FIFO.

| Bit        | Name       | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                       |
|------------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved   | 0x0000      | resd | Kept at default value.                                                                                                                                                                                                                                                                                                            |
| Bit 15: 0  | INEPTXFSAV | 0x0200      | ro   | IN endpoint TxFIFO space available<br>Indicates the amount of free space in the endpoint transmit FIFO. Values are in terms of 32-bit words.<br>0x0: Endpoint transmit FIFO is full<br>0x1: 1 word available<br>0x02: 2 words available<br>0xn: n words available (0 < n < 512)<br>0x200: Remaining 512 words<br>Others: Reserved |

### 21.6.5.24 OTGFS/HS device OUT endpoint-x transfer size register (OTGFS/HS\_DOEPTSI<sub>x</sub>) (x=1...7, where x is endpoint number)

The application must set this register before enabling endpoint x. Once the endpoint x is enabled using the endpoint enable pin in the device endpoint x control register, the controller modifies this register. The application can only read this register as long as the controller clears the endpoint enable bit.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 30: 29 | RXDPID   | 0x0         | ro   | <p>Received data PID<br/>Applies to synchronous OUT endpoints only.<br/>This is the data PID received in the last packet.</p> <p>00: DATA0<br/>01: DATA2<br/>10: DATA1<br/>11: MDATA</p> <p>SETUP packet count<br/>Applies to synchronous OUT endpoints only. Indicates the number of back-to-back SETUP data packets the endpoint can receive.</p> <p>01: 1 packet<br/>10: 2 packets<br/>11: 3 packets</p>                   |
| Bit 28: 19 | PKTCNT   | 0x000       | rw   | <p>Packet count<br/>Indicates the number of USB packets transmitted on the endpoint.</p> <p>This field is decremented every time a packet is written to the receive FIFO (maximum packet size and short packet)</p>                                                                                                                                                                                                           |
| Bit 18: 0  | XFERSIZE | 0x00000     | rw   | <p>Transfer size<br/>Indicates the transfer size (in bytes) for the current endpoint. The controller interrupts the application when the transfer size becomes 0. The transfer size can be set to the maximum packet size of the endpoint, to be interrupted at the end of each packet.</p> <p>The controller decrements this field every time a packet is read from the receive FIFO and written to the external memory.</p> |

### 21.6.5.25 OTGHS device OUT endpoint-x DMA address register (OTGHS\_DOEPDMAx) (x=1...7, where x is endpoint number)

| Bit      | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|---------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | DMAADDR | 0x00000000  | rw   | <p>DMA Address<br/>This bit holds the start address of the external memory for storing or fetching endpoint data.</p> <p>Note: For control endpoints, this filed controls OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten. This register is incremented on every AHB transaction. The application can give only a word-aligned address.</p> |

## 21.6.6 Power and clock control registers

### 21.6.6.1 OTGFS/HS power and clock gating control register (OTGFS/HS\_PCGCCTL)

This register is available in host and device modes.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                 |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 5 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                  |
| Bit 4     | SUSPENDM | 0x0         | ro   | PHY suspend<br>Indicates that the PHY has been suspended.                                                                                                                                                                   |
| Bit 3: 1  | Reserved | 0x0         | resd | Kept at default value.                                                                                                                                                                                                      |
| Bit 0     | STOPPCLK | 0x0         | rw   | Stop PHY clock<br>The application uses this bit to stop PHY clock when the USB is suspended, session is invalid or device is disconnected. The application clears this bit when the USB is resumed or a new session starts. |

## 22 HICK auto clock calibration (ACC)

### 22.1 ACC introduction

The HICK auto clock calibration (HICK ACC) uses the USB-generated SOF signal (1 ms of period) as a reference signal to sample and calibrate the HICK clocks.

The main purpose of this module is to provide a clock of  $48\text{MHz} \pm 0.25\%$  for the USB device.

It is able to make the calibrated frequency as close to the target frequency as possible by means of "cross and return" algorithm.

### 22.2 Main features

- Programmable center frequency
- Programmable boundary frequency that triggers calibration function
- Center frequency precision  $\pm 0.25\%$
- Status detection flags
  - Calibration ready flag
  - Error detection flag
  - Reference signal lost error flag
- Two interrupt sources with flags
  - Calibration ready flag
  - Reference signal lost error flag
- Two calibration modes: coarse calibration and smooth calibration

### 22.3 Interrupt requests

Table 22-1 ACC interrupt requests

| Interrupt event       | Event flag | Enable bit |
|-----------------------|------------|------------|
| Calibration ready     | CALRDY     | CALRDYIEN  |
| Reference signal lost | RSLOST     | EIEN       |

ACC interrupt events are linked to the same interrupt vector (see [Figure 22-1](#)). Interrupt events include:

- During calibration process: When the calibration gets ready or reference signal lost occurs, the corresponding interrupt will be generated if the corresponding enable bit is enabled.

Figure 22-1 ACC interrupt mapping diagram



### 22.4 Functional description

Auto clock calibration (HICK ACC), which uses the SOF signal (1 ms of period) generated on USB module as a reference signal, implements the sampling and calibration of the HICK clocks. In particular, the HICK clock frequency can be calibrated to a precision of  $\pm 0.25\%$  so as to meet the needs of the high-precision clock applications such as USB-based applications.

The signals of the module are connected to the CRM and HICK inside the microcontroller instead of being connected to the pins externally.

- **CRM\_HICKCAL:** the HICKCAL signal in the CRM control module. This signal is used to calibrate the HICK in bypass mode. Its value is defined by the HICKCAL[7:0] in the CRM\_CTRL register.
  - **CRM\_HICKTRIM:** the HICKTRIM signal in the CRM control module. This signal is used to calibrate the HICK in bypass mode. Its value is defined by the HICKTRIM[5: 0] in the CRM\_CTRL register.
- The default value of the HICK is 32, which can be calibrated to  $8\text{MHz} \pm 0.25\%$ . The HICK frequency can be adjusted by 20kHz (design value) each time the CRM\_HICKTWK value changes. In other words, the HICK output frequency will increase by 20kHz each time the CRM\_HICKTWK value is decremented by one; the HICK output frequency will reduce by 20kHz each time the CRM\_HICKTWK value is incremented by one.
- **USB\_SOF:** USB Start-of-Frame signal given by the USB device. Its high-level width is 64 system clock cycles with 1 ms period of pulse signal.
  - **HICKCLK:** HICK clock. The original HICK output clock frequency is 48MHz, but the sampling clock used by the HICK calibration module is frequency divider (1/6) clock, about 8MHz.
  - **HICKCAL:** HICK module calibration signal. For the HICK clock divided by 6, the HICK clock frequency will change by 40KHz (design value) each time the HICKCAL changes, which is a positively correlated relationship. In other words, the HICK clock frequency will increase by 40KHz (design value) each time the HICKCAL is incremented by one; the HICK clock frequency will reduce by 40KHz each time the HICKCAL is decremented by one.
  - **HICKTRIM:** HICK module calibration signal. For the HICK clock divided by 6, the HICK clock frequency will change by 20KHz (design value) each time the HICKTRIM changes, which is a positively correlated relationship.

Refer to [Section 22.6](#) for more information about the bit definition in the registers.

Figure 22-2 ACC block diagram



## 22.5 Principles

**USB\_SOF period signal:** 1ms of period must be accurate, which is a prerequisite for the normal operation of an auto calibration module.

**Cross-return algorithm:** This is used to calculate a calibration value closest to the theoretic value. In theory, the actual frequency after calibration can be adjusted to be within an accurate range of about 0.5 steps from the target frequency (8MHz).

Figure 22-3 Cross-return algorithm



From the above figure, auto calibration function will adjust the HICKCAL or HICKTWK according to the specified step once the conditions for triggering auto calibration are reached.

### Cross:

After the auto calibration condition is met, the actual sampling data within the first 1ms period will be either less than C2, or greater than C2.

When this value is less than C2, the auto calibration module will start increasing either the HICKCAL or HICKTWK according to the step definition until the actual sampling value is greater than C2. In this way, the actual value will cross over C2 from small to large.

When this value is greater than C2, the auto calibration module will decrease either the HICKCAL or HICKTWK according to the step definition until the actual sampling value become less than C1. In this way, the actual value will cross over C2 from large to small.

### Return:

After cross operation is completed, the actual value closest to C2 can be obtained by comparing the difference (calculated as absolute value) between the actual sampling value and C2 before and after crossing C2 so as to get the best calibration value HICKCAL or HICKTWK.

If the difference after crossing is less than the one before crossing C2, the calibration value after crossing prevails, and stops the calibration process until the next condition for auto calibration appears.

If the difference after crossing is greater than the one before crossing C2, the calibration value before crossing prevails, and it will return by one step to the one before crossing, and stops the calibration process until the next condition for auto calibration appears.

According to the cross-return strategy, in theory, it is possible to get the frequency accuracy that is 0.5 steps away from the center frequency.

Four conditions for enabling auto calibration function are as follows:

1. The rising edge of the CANLON (from 0 to 1)
2. When CALON=1, reference signal is lost and restored
3. When the sample counter is less than C1
4. When the sample counter is greater than C3

Even though the sampling counter is between C1 and C3, at the rising edge the CANLON, the auto calibration module can also be activated so that the HICK frequency can be adjusted to be within a range of 0.5 steps of the center frequency after the CANLON is enabled.

Under one of the above-mentioned circumstances, the HICK frequency can be calibrated to be within 0.5 steps of the center frequency. To achieve the best calibration accuracy, it is recommended to remain step as 1 (default value). If the step is set to 0, either HICKCAL or HICKTWK cannot be calibrated.

## 22.6 Register description

Refer to the list of abbreviations used in register descriptions.

These peripheral registers must be accessed by words (32 bits).

### 22.6.1 ACC register map

Table 22-2 ACC register map and reset values

| Register  | Offset | Reset value  |
|-----------|--------|--------------|
| ACC_STS   | 0x00   | 0x0000 000   |
| ACC_CTRL1 | 0x04   | 0x0000 0100  |
| ACC_CTRL2 | 0x08   | 0x0000 2080  |
| ACC_C1    | 0x0C   | 0x0000 1F2C  |
| ACC_C2    | 0x10   | 0x0000 1F40  |
| ACC_C3    | 0x14   | 0x00000 1F54 |

### 22.6.2 Status register (ACC\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 9 | Reserved | 0x00000000  | resd | Kept at default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 1     | RSLOST   | 0x0         | ro   | Reference Signal Lost<br>0: Reference Signal is not lost<br>1: Reference Signal is lost<br>Note: During the calibration process, when the sample counter of the calibration module is twice that of C2, if a SOF reference signal is not detected, it means that the reference signal is lost. The internal status machine will move to the idle state unless another SOF signal is detected; otherwise, the internal clock sample counter remains 0. The RSLOST bit is immediately cleared after the CALON bit is cleared or when the RSLOST is written with 0. Reference signal detection occurs only when CALON=1. |
| Bit 0     | CALRDY   | 0x0         | ro   | Internal high-speed clock calibration ready<br>0: Internal 8MHz oscillator calibration is not ready<br>1: Internal 8MHz oscillator calibration is ready<br>Note: This bit is set by hardware to indicate that internal 8MHz oscillator has been calibrated to the frequency closest to 8MHz. The CALRDY is immediately cleared after the CALON bit is cleared or when the CALRDY is written with 0.                                                                                                                                                                                                                   |

### 22.6.3 Control register 1 (ACC\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x00000     | resd | Forced to 0 by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 11: 8  | STEP     | 0x1         | rw   | Calibrated step<br>This field defines the value after each calibration.<br>Note: It is recommended to set the step bit in order to get a more accurate calibration result. While ENTRIM=0, only the HICKCAL is calibrated. If the step is incremented or decremented by one, the HICKCAL will be incremented or decremented by one accordingly, and the HICK frequency will increase or decrease by 40KHz (design value). This is a positive relationship.<br>While ENTRIM=1, only the HICKTRIM is calibrated. If the step is incremented or decremented by one, the HICKTRIM will be incremented or decremented by one accordingly, and the HICK frequency will increase or decrease by 20KHz (design value). This is a positive relationship. |

|          |           |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 7: 6 | Reserved  | 0x0 | rw | Forced by hardware to 0<br>CALRDY interrupt enable<br>This bit is set or cleared by software.<br>0: Interrupt generation disabled<br>1: ACC interrupt is generated when CALRDY=1 in the ACC_STS register                                                                                                                                                                                                                                                                                                        |
| Bit 5    | CALRDYIEN | 0x0 | rw | RSLOST error interrupt enable<br>This bit is set or cleared by software.<br>0: Interrupt generation disabled<br>1: ACC interrupt is generated when RSLOST=1 in the ACC_STS register                                                                                                                                                                                                                                                                                                                             |
| Bit 4    | EIEN      | 0x0 | rw | Forced to 0 by hardware<br>Enable trim<br>This bit is set or cleared by software.<br>0: HICKCAL is calibrated.<br>1: HICKTRIM is calibrated.<br>Note: It is recommended to set ENTRIM=1 in order to get higher calibration accuracy.                                                                                                                                                                                                                                                                            |
| Bit 3: 2 | Reserved  | 0x0 | rw | Calibration on<br>This bit is set or cleared by software.<br>0: Calibration disabled<br>1: Calibration enabled, and starts searching for a pulse on the USB_SOF.<br>Note: This module cannot be used without the USB_SOF reference signal. If there are no requirements on the accuracy of the HICK clock, it is unnecessary to enable this module.                                                                                                                                                             |
| Bit 0    | CALON     | 0x0 | rw | Internal high-speed auto clock trimming<br>This field is read-only, but not written.<br>Internal high-speed clock is adjusted by ACC module, which is added to the ACC_HICKCAL[7: 0] bit. These bits allow the users to input a trimming value to adjust the frequency of the HICKRC oscillator according to the variations in voltage and temperature.<br>The default value is 32, which can trim the HICK to 8MHz±0.25. The trimming value is 20kHz (design value) between two consecutive ACC_HICKTWK steps. |

## 22.6.4 Control register 2 (ACC\_CTRL2)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved | 0x00000     | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 13: 8  | HICKTRIM | 0x20        | ro   | Internal high-speed auto clock calibration<br>This field is read-only, but not written.<br>Internal high-speed clock is adjusted by ACC module.<br>These bits allow the users to input a trimming value to adjust the frequency of the HICKPC oscillator according to the variations in voltage and temperature.<br>The default value is 32, which can trim the HICK to 8MHz±0.25. The trimming value is 20kHz (design value) between two consecutive ACC_HICKTWK steps.  |
| Bit 7: 0   | HICKCAL  | 0x80        | ro   | Internal high-speed auto clock calibration<br>This field is read-only, but not written.<br>Internal high-speed clock is adjusted by ACC module.<br>These bits allow the users to input a trimming value to adjust the frequency of the HICKPC oscillator according to the variations in voltage and temperature.<br>The default value is 128, which can trim the HICK to 8MHz±0.25. The trimming value is 40kHz (design value) between two consecutive ACC_HICKCAL steps. |

## 22.6.5 Compare value 1 (ACC\_C1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                                                     |
| Bit 15: 0  | C1       | 0x1F2C      | rw   | Compare 1<br>This value is the lower boundary for triggering calibration, and its default value is 7980. When the number of clocks sampled by ACC in 1ms period is less than or equal to C1, auto calibration is triggered automatically.<br>When the actual sampling value (number of clocks in 1ms) is greater than C1 but less than C3, auto calibration is not enabled. |

## 22.6.6 Compare value 2 (ACC\_C2)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 15: 0  | C2       | 0x1F40      | rw   | Compare 2<br>This value defines the number of clocks sampled for 8MHz (ideal frequency) clock in 1ms period , and its default value is 8000 (theoretical value)<br>As a center point of cross-return strategy, this value is used to calculate the calibration value closest to the theoretical value. In theory, the actual frequency after calibration can be trimmed to be within an accuracy of 0.5 steps from the target frequency (8MHz) |

## 22.6.7 Compare value 3 (ACC\_C3)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                           |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Forced to 0 by hardware                                                                                                                                                                                                                                                                                                                               |
| Bit 15: 0  | C3       | 0x1F54      | rw   | Compare 3<br>This value is the upper boundary for triggering calibration. When the number of clock sampled by ACC in 1ms period is greater than or equal to C3, auto calibration is triggered automatically.<br>When the actual sampling value (number of clocks in 1ms period) is greater than C1 but less than C3, auto calibration is not enabled. |

## 23 Quad-SPI interface (QSPI)

### 23.1 QSPI introduction

The QSPI interface consists of a command-based slave port, an XIP slave port (direct address map access) and QSPI controller dedicated to SPI Flash command execution. The command-based slave port is used to access registers and data ports, and the XIP slave port reads data from direct address mapping. Additionally, the QSPI allows users to access data via AHB data port in IPO or DMA mode.

### 23.2 QSPI main features

- DMA handshake mode and CPU PIO mode
- SPI serial mode, dual/quad output mode, dual/quad I/O mode and DPI/QPI mode
- XIP port (direct address map read/write)
- XIP port prefetch function (2-channel read cache)
- 128-byte TxFIFO/RxFIFO depth
- Programmable divider
- Data encryption

Figure 23-1 QSPI block diagram



### 23.3 QSPI functional overview

#### 23.3.1 QSPI command slave port

The QSPI has a command slave port that contains registers and data ports. The users can access registers or data ports using such port. The command word register must be written sequentially (CMD\_W3 is the last to be written) and is accessible in words, while any other registers (including data port register) can be accessed by bytes, half-words and words.

#### 23.3.2 CPU PIO mode

The data port can be accessed in either PIO or DMA mode. In PIO mode, there is a need for users to poll the RxFIFO / TxFIFO registers (0x18). When the RxFIFO is ready, it allows users to read or store the entire RxFIFO data. When the TxFIFO is ready, it can be written with the entire data. As a result, polling these registers is required in PIO mode.

### 23.3.3 DMA handshake mode

The DMA mode is another solution to access data ports. The DMA controller register must be programmed as DMA handshake mode. In this mode, the host controller sends a DMA request when the receive/transmit FIFO threshold is reached. The threshold values are in terms of words. The DMA request is still sent when the last data transfer is less than the threshold.

When DMA is used in P2M mode (peripheral to memory), that is, when QSPI reads data, the minimum transmit bit is in WORD. Thus DMA length needs to be in the format of WORD unit, and so does the data size.

When 2 DMA are used in M2P mode (memory to peripheral), that is, when QSPI writes data, the maximum length is 128 bytes for a single transfer. If more than 128 bytes, it is necessary to perform multiple DMA transfers, in the format of Byte unit.

Figure 23-2 DMA handshake mode



### 23.3.4 XIP port (direct address map read/write)

The QSPI offers a XIP slave port (direct address mapping read/write) for users to perform a direct access to system addresses. In this case, users can only use 0x10 register to select a command slave port or a XIP port, or read other registers than data register (0x100).

It should be noted that when reading Flash memory using this XIP port, the Abort function (bit [8] in the 0x10 register) cannot be used (meaning that the bit [20] of the 0x10 register is set to 1), and the XIP port cannot be aborted with this bit, which means that port switch must be performed in sequence. The user's system must have a main Flash memory, in which the user can load the port switch code and perform switching operation.

### 23.3.5 XIP port prefetch

The XIP port supports read prefetch with 2-channel associated read cache.

### 23.3.6 SPI device operation

#### Command phase

The QSPI operations are implemented using commands. These commands indicate operational purposes and SPI operating modes (multiple-line communication).

*Note: The command phase can be configured as 1 or 2 byte. When it is configured as 2 byte, it sends two duplicate 1-byte commands – only 1 byte register is used to store command words.*

#### Address phase

An address is required when reading, writing or erasing memories.

In command mode, the address length can be 0-4 bytes; in XIP mode, the address length can be 3 bytes or 4 bytes.

#### Dummy-cycles phase

This dummy-cycles phase is used to allow the memory to prepare for the to-be-read data. This phase is available in XIP mode and command mode, which is configured through DUM2 and XIPR\_DUM2 respectively. Additionally, the number of cycles during this dummy phase applies to XIP write timing, which can be configured through the XIPW\_DUM2. It is usually set to 0 instead.

#### Data phase

It is used as input while reading memory data/status register, and as output while writing memory.

#### Serial interface mode (1-1-1)

The host controller supports a SPI protocol (mode 0 and mode 3). The command queue register must be configured according to SPI device specification. Refer to Figure 23-3 and Figure 23-10 for more information on how to program a command queue.

To execute a write enable command, set instruction code to 06h, enable write operation, and set instruction length to 1. Refer to Figure 23-3 for details.

Figure 23-3 Write enable



To execute a page programming command, set instruction code to 02h, configure address register and address size, enable write operation and set instruction length to 1.

Figure 23-4 Page programming



To execute a read status command, set instruction code to 05h/35h, enable read status, select read status through hardware or software, and set instruction length to 1. Refer to Figure 28-5 for more information.

Figure 23-5 Status read



To execute a read data command, set instruction code and length to 1 byte, address/address size to 3 bytes, and set write instruction to 0. Refer to Figure 28-6 for more information.

Figure 23-6 Data read



**Dual mode (1-1-2)**

To execute a quick read dual output command, set instruction code/length to 1, address/address size to 3 bytes, set the second dummy cycle to 8, and enable dual mode. Refer to Figure 28-7 for details

Figure 23-7 read dual command

**Dual I/O mode (1-2-2)**

To execute a quick read dual I/O command, set code/ length, configure address/address size, enable continuous read mode, continuous read mode code and dual IO mode operation commands, see Figure 23-8 for details.

Figure 23-8 Quick read dual-wire I/O command

**Quad mode (1-1-4)**

To execute a quick read quad I/O command, set instruction code/length, address/address size, configure the second dummy period and enable quad mode. Refer to Figure 23-9 for more information.

Figure 23-9 Read quad output

**Quad I/O mode (1-4-4)**

To execute a quick read quad I/O command, set instruction code/length, address/address size, the second dummy period, enable continuous read mode/continuous read mode code and enable quad I/O mode. Refer to Figure 23-10 for more information.

Figure 23-10 Quick read quad I/O command



To execute DPI (2-2-2) mode, set code/length, address/address length, the second dummy cycles and enable dual DPI mode operating command. For more information, see Figures below.

Figure 23-11 Dual DPI command



To execute QPI (4-4-4) mode, please set code/length, address/address length, the second dummy cycles and enable QPI mode operating command. For more information, see Figures below.

Figure 23-12 Quad QPI command



### XIP read/write D mode

To execute XIP read/write D mode, please set instruction code/length, address/address length, the second dummy cycle, select serial/dual/dual IO/quad IO or DPI/QPI mode, set read/write D mode and program D mode counter with upper threshold value.

When reading/writing continued address by XIP port, it will keep reading/writing data until the upper threshold value is reached or until an address is interrupted.

While reading,  $N(\text{byte}) = \text{XIPR\_DCNT} * 4$ ; while writing,  $N(\text{byte}) = \text{XIPW\_DCNT} * 4$

For more information, see the figure below.



### XIP read/write T mode

To execute XIP read/write T mode, please set instruction code/length, address/address length, the second dummy cycle, select serial/dual/dual IO/quad IO or DPI/QPI mode, set read/write T mode and program T mode counter.

While XIP port reading/writing continued address at an interval, it will disable CLK wait states after reading or writing data. If the waiting time goes above the upper threshold value or when the next address for read or write access is interrupted (becomes discontinuous), the continued read or write operation stops.

While reading,  $T(\text{cycle}) = \text{XIPR\_TCNT}$ ; while writing,  $T(\text{cycle}) = \text{XIPW\_TCNT}$

For more information, see the figure below.



## 23.4 QSPI registers

These registers must be accessed by bytes (8-bit), half-words (16-bit) or words (32-bit).

Table 23-1 QSPI register map and reset values

| Register   | Offset | Reset value  |
|------------|--------|--------------|
| CMD_W0     | 0x0    | 0x0000 0000  |
| CMD_W1     | 0x4    | 0x0100 0003  |
| CMD_W2     | 0x8    | 0x0000 0000  |
| CMD_W3     | 0xC    | 0x0000 0000  |
| CTRL       | 0x10   | 0x0010 0083  |
| FIFOSTS    | 0x18   | 0x0000 0001  |
| CTRL2      | 0x20   | 0x0000 0000  |
| CMDSTS     | 0x24   | 0x0000 0000  |
| RSTS       | 0x28   | 0x0000 0000  |
| FSIZE      | 0x2C   | 0xF0000 0000 |
| XIP CMD_W0 | 0x30   | 0x0000 3000  |
| XIP CMD_W1 | 0x34   | 0x0000 2000  |
| XIP CMD_W2 | 0x38   | 0x0F01 0F01  |
| XIP CMD_W3 | 0x3C   | 0x0000 0000  |
| CTRL3      | 0x40   | 0x0000 0000  |
| REV        | 0x50   | 0x0001 0500  |
| DT         | 0x100  | 0x0000 0000  |

### 23.4.1 Command word 0 (CMD\_W0)

No-wait states, assessable by words.

| Bit       | Name   | Reset value | Type | Description                                                                                                                                                                                 |
|-----------|--------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | SPIADR | 0x0         | rw   | SPI Flash address<br>This register is used to define the value of SPI Flash addresses, and sends them to SPI Flash. The address byte is determined by the bit [2:0] of the CMD_W1 register. |

### 23.4.2 Command word 1 (CMD\_W1)

No-wait states, assessable by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                           |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 29 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                            |
| Bit 28     | PEMEN    | 0x0         | rw   | Performance enhanced mode enable<br>Locates between the address and the second dummy state. In this mode, the command status after the second read command can be removed. Do not set this bit when CMD_W2=0.<br>0: Performance enhanced mode disabled<br>1: 1-byte Performance enhanced mode enabled |
| Bit 27: 26 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                            |

---

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 25: 24 | INSLEN   | 0x1 | rw   | <p>Instruction code length<br/>Instruction code is required for SPI Flash command execution. The instruction code length varies from SPI Flash supplier to SPI Flash supplier. Thus this register can be used to program the desired instruction code length. Typically, the instruction code is one-byte length. However, if the user sets two-byte instruction code, the host controller sends this instruction code twice.</p> <p>00: No instruction code. It cannot be used until the continuous read mode command is completed.<br/>01: 1-byte instruction code<br/>10: 2-byte instruction code (repeated instruction code)<br/>11: Reserved</p> |
| Bit 23: 16 | DUM2     | 0x0 | rw   | <p>Second dummy state cycle<br/>The second dummy cycle is located between the address and data state, excluding performance enhanced mode status. The user can check whether there is a dummy state between the address and data status in SPI Flash specification. The host controller sends logic 1 in a dummy cycle.</p> <p>0: No second dummy state<br/>1~32: 1 dummy second period~32 dummy second period</p>                                                                                                                                                                                                                                    |
| Bit 15: 3  | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 2: 0   | ADRLEN   | 0x3 | rw   | <p>SPI address length<br/>This field defines the number of bytes of the SPI Flash address, ranging from one to four bytes.</p> <p>000: No address state<br/>001: 1-byte address<br/>010: 2-byte address<br/>011: 3-byte address<br/>100: 4-byte address<br/>Others: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                      |

---

### 23.4.3 Command word 2 (CMD\_W2)

No-wait states, accessible by words.

---

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                          |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | DCNT | 0x0         | rw   | <p>Read/Write data counter<br/>This bit must be set to 0 when executing read status command.</p> <p>0: No read/write data<br/>1~FFFFFFFF: 1~FFFFFF byte data<br/>Note: This register must not be padded with 0 for data read or write. However, for "read status" or "write enable" instruction, this register must be set to 0.</p> |

---

### 23.4.4 Command word 3 (CMD\_W3)

No-wait states, accessible by words.

---

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                    |
|------------|--------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | INSC   | 0x00        | rw   | <p>Instruction code<br/>This code is set to enable SPI Flash command.</p>                                                                                                                                                                      |
| Bit 23: 16 | PEMOPC | 0x00        | rw   | <p>Performance enhanced mode operation code<br/>This field works with the PEMEN bit. This code can be padded to execute performance enhanced mode. Follow the corresponding Flash specification document to write the corresponding value.</p> |

---

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 7: 5   | OPMODE   | 0x0 | rw   | <p>SPI Operation mode<br/>           000: Serial mode (1-1-1)<br/>           001: Dual-wire mode (1-1-2)<br/>           010: Quad mode (1-1-4)<br/>           011: Dual-wire I/O mode (1-2-2)<br/>           100: Quad I/O mode (1-4-4)<br/>           101: DPI mode (2-2-2)<br/>           110: QPI mode (4-4-4)<br/>           Others: Reserved</p>                                                                                 |
| Bit 4      | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 3      | RSTSC    | 0x0 | rw   | <p>Read SPI status configuration<br/>           This bit is valid only when read state and write are enabled. The user must send a SPI read state command.<br/>           0: Hardware read. The controller keeps polling until the state is ready (not busy) and feedbacks to the status register.<br/>           1: Software read. Read status ones and feedback to the status register until the user is able to read it.</p>       |
| Bit 2      | RSTSEN   | 0x0 | rw   | <p>Read SPI status enable<br/>           This bit is valid when WEN = "0", and the user must send SPI read status command.<br/>           0: Read SPI status disabled<br/>           1: Read SPI status enabled</p>                                                                                                                                                                                                                   |
| Bit 1      | WEN      | 0x0 | rw   | <p>Write data enable<br/>           This bit is used to enable SPI write data, excluding read data or read status (read data return path); the user must set write enable bit=1 for other SPI commands.<br/>           Note: Write enable must be set to 1 in data write or Flash erase command. The write enable must be set to 0 only in read data or read status command.<br/>           0: Disabled<br/>           1: Enabled</p> |
| Bit 0      | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                            |

### 23.4.5 Control register (CTRL)

No-wait states, accessible by bytes, half-words and words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                         |
| Bit 21     | KEYEN    | 0x0         | rw   | <p>SPI data encryption key enable<br/>           0: SPI data encryption key disabled<br/>           1: SPI data encryption key enabled<br/>           When this bit is enabled, raw data is converted into ciphertext and written into the QSPI peripheral through QSPIKEY. While read, data is decrypted into plaintext and sends to the CPU.</p> |
| Bit 20     | XIPSEL   | 0x1         | rw   | <p>XIP port selection<br/>           Read SPI Flash data from the following ports:<br/>           0: Command slave port<br/>           1: XIP port<br/>           When this bit is switched, the QSPI sends automatically an Abort signal. The user can send a command only after the completion of Abort function.</p>                            |
| Bit 19     | XIPRCMDF | 0x0         | rw   | XIP read command flush                                                                                                                                                                                                                                                                                                                             |

---

|            |          |      |      |                                                                                                                                                                                                                                    |
|------------|----------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 18: 16 | BUSY     | 0x0  | rw   | Busy bit of SPI status<br>The host polls this busy bit and remains in hardware read state.<br>000~111: bit 0~bit7                                                                                                                  |
| Bit 15: 9  | Reserved | 0x00 | resd | Kept at its default value.                                                                                                                                                                                                         |
| Bit 8      | ABORT    | 0x0  | rw   | Refresh all commands/FIFOs and reset state machine<br>When an abnormal Abort operation occurs, users must write this bit (it is automatically cleared to 0)<br>0: No abort requested<br>1: Abort requested                         |
| Bit 7      | XIPIDLE  | 0x1  | ro   | XIP port idle status<br>0: XIP port is busy<br>1: XIP port is idle                                                                                                                                                                 |
| Bit 6: 5   | Reserved | 0x0  | resd | Kept at its default value.                                                                                                                                                                                                         |
| Bit 4      | SCKMODE  | 0x0  | rw   | sckout mode<br>0: For mode 0, the sck_out is low in idle state, and data is sampled on the first edge<br>1: For mode 3, the ck_out is high in idle state, and data is sampled on the second edge                                   |
| Bit 3      | Reserved | 0x0  | resd | Kept at its default value.                                                                                                                                                                                                         |
| Bit 2: 0   | CLKDIV   | 0x3  | rrw  | Clk divider<br>This field is used to divide the spi_clk.<br>000: Divided by 2<br>001: Divided by 4<br>010: Divided by 6<br>011: Divided by 8<br>100: Divided by 3<br>101: Divided by 5<br>110: Divided by 10<br>111: Divided by 12 |

---

### 23.4.6 FIFO status register (FIFOSTS)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                     |
|-----------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 2 | Reserved  | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                      |
| Bit 1     | RXFIFORDY | 0x0         | ro   | RxFIFO ready status<br>This bit is set when the RxFIFO is reached, or if the remaining data, which is already the last one, of the RxFIFO is less than the depth of the RxFIFO. |
| Bit 0     | TXFIFORDY | 0x1         | ro   | TxFIFO ready status<br>This bit is set when the TxFIFO is empty so that users are able to transfer data to the TxFIFO until it is full.                                         |

### 23.4.7 Control register 2 (CTRL2)

No-wait states, accessible by bytes, half-words and words.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                        |
|------------|-------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved    | 0x0000 0    | resd | Kept at its default value.                                                                                                                                                                                                                                                         |
| Bit 13: 12 | RXFIFO THOD | 0x0         | rw   | <p>This field is used to program the level value to trigger RxFIFO threshold interrupt for DMA handshake mode. The value is in terms of word.</p> <p>The trigger value is the data in the RxFIFO.</p> <p>00: 8 WORD<br/>01: 16 WORD<br/>10: 24 WORD<br/>11: Reserved</p>           |
| Bit 11: 10 | Reserved    | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                         |
| Bit 9: 8   | TXFIFO THOD | 0x0         | rw   | <p>This field is used to program the level value to trigger TxFIFO threshold interrupt for DMA handshake mode. The value is in terms of word.</p> <p>The trigger value is the data available in the TxFIFO.</p> <p>00: 8 WORD<br/>01: 16 WORD<br/>10: 24 WORD<br/>11: Reserved</p> |
| Bit 7: 2   | Reserved    | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                         |
| Bit 1      | CMDIE       | 0x0         | rw   | <p>Command complete Interrupt enable</p> <p>0: Command complete Interrupt disabled<br/>1: Command complete Interrupt enabled</p>                                                                                                                                                   |
| Bit 0      | DMAEN       | 0x0         | rw   | <p>DMA enable</p> <p>Note: This bit must be disabled before shifting from command-based slave port to XIP port.</p>                                                                                                                                                                |

### 23.4.8 Command status register (CMDSTS)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name     | Reset value | Type | Description                                                   |
|-----------|----------|-------------|------|---------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                    |
| Bit 0     | CMDSTS   | 0x0         | rw1c | Command complete status<br>It is set at the end of a command. |

### 23.4.9 Read status register (RSTS)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                            |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x0000 00   | resd | Kept at its default value.                                                                                                                                                             |
| Bit 7: 0  | SPISTS   | 0x00        | ro   | <p>SPI Read status</p> <p>The host sends a read SPI Flash status command and stores the returned data in this register. By reading it, the user can check the status of SPI Flash.</p> |

### 23.4.10 Flash size register (FSIZE) (FSIZE)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                             |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | SPIFSIZE | 0xF000 0000 | rw   | SPI Flash Size<br>In direct address map mode, system address is always greater than that of SPI Flash. The user must mask the upper bits of the system address to match SPI Flash size. |

### 23.4.11 XIP command word 0 (XIP CMD\_W0)

No-wait states, accessible by words.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved    | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 19: 12 | XIPR_INSC   | 0x03        | rw   | XIP read instruction code<br>This field is set to execute SPI Flash command of XPI read.                                                                                                                                                                                                                                                                                                             |
| Bit 11     | XIPR_ADRLEN | 0x0         | rw   | XIP read address length<br>This bit defines the number of bytes of SPI Flash address.<br>The user can uses this bit to program a 3-byte or 4-byte XIP read address.<br>0: 3-byte address<br>1: 4-byte address                                                                                                                                                                                        |
| Bit 10: 8  | XIPR_OPMODE | 0x0         | rw   | XIP read Operation mode<br>000: Serial mode (1-1-1)<br>001: Dual-wire mode (1-1-2)<br>010: Quad mode (1-1-4)<br>011: Dual-wire IO mode (1-2-2)<br>100: Quad IO mode (1-4-4)<br>101: DPI mode (2-2-2)<br>110: QPI mode (4-4-4)<br>111: Reserved                                                                                                                                                       |
| Bit 7: 0   | XIPR_DUM2   | 0x00        | rw   | XIP Read second dummy cycle<br>The second dummy state is located between the address and data status, excluding continuous read mode status.<br>The user can check if there is a dummy state between the address and data status in SPI Flash specification. The host controller issues logic 1 in a dummy cycle.<br>0: No second dummy state<br>1~32: 1 dummy second period~32 dummy second periods |

### 23.4.12 XIP command word 1 (XIP CMD\_W1)

No-wait states, accessible by words.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                     |
|------------|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 18 | Reserved    | 0x000       | resd | Kept at its default value.                                                                                                                                                                                      |
| Bit 19: 12 | XIPW_INSC   | 0x02        | rw   | XIP write instruction code<br>The user can set this field to enable a SPI Flash command of XIP write.                                                                                                           |
| Bit 11     | XIPW_ADRLEN | 0x0         | rw   | XIP write address length<br>This bit defines the number of bytes of SPI Flash address.<br>The user can uses this bit to program a 3-byte or 4-byte XIP write address.<br>0: 3-byte address<br>1: 4-byte address |

|           |             |      |    |                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-------------|------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 10: 8 | XIPW_OPMODE | 0x0  | rw | XIP write operation mode<br>000: Serial mode (1-1-1)<br>001: Dual-wire mode (1-1-2)<br>010: Quad mode (1-1-4)<br>011: Dual IO mode (1-2-2)<br>100: Quad IO mode (1-4-4)<br>101: DPI mode (2-2-2)<br>110: QPI mode (4-4-4)<br>111: Reserved                                                                                                                                                            |
| Bit 7: 0  | XIPW_DUM2   | 0x00 | rw | XIP Write second dummy cycle<br>The second dummy state is located between the address and data status, excluding continuous read mode status.<br>The user can check if there is a dummy state between the address and data status in SPI Flash specification. The host controller issues logic 1 in a dummy cycle.<br>0: No second dummy state<br>1~32: 1 dummy second period~32 dummy second periods |

### 23.4.13 XIP command word 2 (XIP CMD\_W2)

No-wait states, accessible by words.

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | XIPW_SEL  | 0x0         | rw   | XIP write mode select<br>0: Mode D<br>1: Mode T<br>The XIP slave port can be used for the improvement of read/write process and performance.<br>Mode D: When data are written to the consecutive addresses, put a limit on the maximum data count (DCNT) in a single write operation<br>Mode T: When two consecutive data are written and the addresses are also continuous, and the interval is less than a specified time (TCNT), then they are combined into one command. |
| Bit 30: 24 | XIPW_TCNT | 0x0F        | rw   | This indicates the time counter that is used to judge time interval in mode T.<br>Value is in terms of sck_out period.<br>This counter is valid when mode T is selected.                                                                                                                                                                                                                                                                                                     |
| Bit 23: 22 | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 21: 16 | XIPW_DCNT | 0x01        | rw   | This indicates the time counter that is used to judge the maximum data count in mode D.<br>Value is in terms of word, and must not be 0.<br>This counter is valid when mode D is selected.                                                                                                                                                                                                                                                                                   |
| Bit 15     | XIPR_SEL  | 0x0         | rw   | XIP read mode select<br>0: Mode D<br>1: Mode T<br>The XIP slave port can be used for the improvement of read/write process and performance.<br>Mode D: When data are read from the consecutive addresses, put a limit on the maximum data count (DCNT) in a single write operation<br>Mode T: When two consecutive data are read and the addresses are also continuous, and the interval is less than a specified time (TCNT), then they are combined into one command.      |

|           |           |      |      |                                                                                                                                                                                            |
|-----------|-----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 14: 8 | XIPR_TCNT | 0x0F | rw   | This indicates the time counter that is used to judge time interval in mode T.<br>Value is in terms of sck_out period.<br>This counter is valid when mode T is selected.                   |
| Bit 7: 6  | Reserved  | 0x0  | resd | Kept at its default value.                                                                                                                                                                 |
| Bit 5: 0  | XIPR_DCNT | 0x01 | rw   | This indicates the time counter that is used to judge the maximum data count in mode D.<br>Value is in terms of word, and must not be 0.<br>This counter is valid when mode D is selected. |

### 23.4.14 XIP command word 3 (XIP CMD\_W3)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                              |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 4 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                               |
| Bit 3     | CSTS     | 0x0         | r    | Cache Status<br>0: Cache validation<br>1: Cache invalid                                                                                                                                                                                                                                                                  |
| Bit 2: 1  | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                               |
| Bit 0     | BYPASSC  | 0x0         | rw   | Bypass Cache Function<br>When this set is to 1, high-speed cache function is disabled by QSPI, and bypassed by all read transfers.<br>This cache function is only applicable to XIP Read only application (extended external Flash). For XIP Read/write application(extended external PSRAM), this bit must be set to 1. |

### 23.4.15 Control register (CTRL3)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                           |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 9 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                                                            |
| Bit 8     | ISPC     | 0x0         | rw   | Input sampling phase correction enable<br>This bit is used to correct sampling phase according to input sampling phase delay and SPI Flash output timing.<br>0: Fixed sampling phase<br>1: Input sampling phase correction is enabled |
| Bit 7: 0  | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                            |

### 23.4.16 Revision register (REV)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name | Reset value | Type | Description           |
|-----------|------|-------------|------|-----------------------|
| Bit 31: 0 | REV  | 0x0001 0500 | ro   | Indicates IP version. |

### 23.4.17 Data port register (DT)

No-wait states, accessible by bytes, half-words and words.

| Bit       | Name | Reset value | Type | Description                                                     |
|-----------|------|-------------|------|-----------------------------------------------------------------|
| Bit 31: 0 | DT   | 0x0000 0000 | rw   | Data port register<br>This port is used for data read or write. |

## 24 Infrared interface (IRTMR)

The IRTMR (Infrared interface) is used to generate IR\_OUT signals that drive an infrared LED in order to achieve infrared control.

The IR\_OUT signals consist of low-frequency modulation envelope and high-frequency carrier signals. The low-frequency modulation envelope signal comes from the TMR10\_C1OUT, while the high-frequency carrier signal is provided by the TMR11\_C1OUT register. The IR\_POL bit in the SCFG\_CFG1 register controls whether the IR\_OUT output is reversed or not. The IR\_OUT signal is output through multiplexed function PB9 or PA13 (multiplexed mode needs to be configured in advance).

Figure 24-1 IRTMR block diagram



# 25 Debug (DEBUG)

## 25.1 Debug introduction

Cortex®-M4F core comes with various debugging features such as halt and single-step support, as well as trace function that is used to check the details of the program execution. The debug features are implemented with a serial wire debug interface.

ARM Cortex®-M4F reference documentation:

- Cortex®-M4 Technical Reference Manual (TRM)
- ARM Debug Interface V5
- ARM CoreSight Design Kit revision r1p0 Technical Reference Manual

## 25.2 Debug and Trace

Debugging features are available to different peripherals. The working state of peripherals can also be configured during debugging session. For timers and watchdogs, the user can select whether or not to stop or continue counting during debugging; For CAN controllers, the user can select whether or not to stop or continue updating receive registers during debugging; For I<sup>2</sup>C, the user can select whether or not to stop or continue SMBUS timeout counting.

In addition, code debugging is supported in Low-power mode. In Sleep mode, the clock programmed by code remains active for HCLK and FCLK to continue to work. In Deepsleep mode, HICK oscillator is enabled to feed FCLK and HCLK.

There are several ID codes inside the MCU, which is accessible by the debugger using the DEBUG\_IDCODE at address 0xE0042000. It is part of the DEBUG and is mapped on the external PPB bus. These codes are accessible using the JTAG debug port or the SWD debug port or by the user software. They are even accessible while the MCU is under system reset.

## 25.3 I/O pin control

The entire AT32F402/405 series supports SWD debugging. They offer two general-purpose IO ports for the purpose of debugging. After reset, the SWD can be immediately used by the debugger, by default.

GPIO and IOMUX registers can be configured to allow users to switch between enabling debugging and disabling debugging feature.

## 25.4 DEBUG registers

*Table 25-1* shows DEBUG register map and reset values.

These peripheral registers must be accessed by word (32 bits).

Table 25-1 DEBUG register address and reset value

| Register         | Offset      | Reset value |
|------------------|-------------|-------------|
| DEBUG_IDCODE     | 0xE004 2000 | 0xFFFF XXXX |
| DEBUG_CTRL       | 0xE004 2004 | 0x0000 0000 |
| DEBUG_APB1_PAUSE | 0xE004 2008 | 0x0000 0000 |
| DEBUG_APB2_PAUSE | 0xE004 200C | 0x0000 0000 |
| DEBUG_SER_ID     | 0xE004 2020 | 0x0000 XX0X |

### 25.4.1 DEBUG device ID (DEBUG\_IDCODE)

MCU integrates an ID code that is used to identify MCU's revision code. The DEBUG\_IDCODE register is mapped on the external PPB bus at address 0xE0042000. This code is accessible by the SW debug port or by the user code.

| Bit         | Name             | Reset value | Type     | Description     |
|-------------|------------------|-------------|----------|-----------------|
| Bit 31: 0   | PID              | 0xXXXX XXXX | ro       | PID information |
| <hr/>       |                  |             |          |                 |
| PID [31: 0] | AT32 part number | FLASH size  | Packages |                 |
| 0x7005_3240 | AT32F405RCT7     | 256KB       | LQFP64   |                 |
| 0x7004_21C1 | AT32F405RBT7     | 128KB       | LQFP64   |                 |
| 0x7005_3242 | AT32F405RCT7-7   | 256KB       | LQFP64   |                 |
| 0x7004_21C3 | AT32F405RBT7-7   | 128KB       | LQFP64   |                 |
| 0x7005_3244 | AT32F405CCT7     | 256KB       | LQFP48   |                 |
| 0x7004_21C5 | AT32F405CBT7     | 128KB       | LQFP48   |                 |
| 0x7005_3246 | AT32F405CCU7     | 256KB       | QFN48    |                 |
| 0x7004_21C7 | AT32F405CBU7     | 128KB       | QFN48    |                 |
| 0x7005_3248 | AT32F405KCU7-4   | 256KB       | QFN32    |                 |
| 0x7004_21C9 | AT32F405KBU7-4   | 128KB       | QFN32    |                 |
| <hr/>       |                  |             |          |                 |
| 0x7005_324A | AT32F402RCT7     | 256KB       | LQFP64   |                 |
| 0x7004_21CB | AT32F402RBT7     | 128KB       | LQFP64   |                 |
| 0x7005_324C | AT32F402RCT7-7   | 256KB       | LQFP64   |                 |
| 0x7004_21CD | AT32F402RBT7-7   | 128KB       | LQFP64   |                 |
| 0x7005_324E | AT32F402CCT7     | 256KB       | LQFP48   |                 |
| 0x7004_21CF | AT32F402CBT7     | 128KB       | LQFP48   |                 |
| 0x7005_3250 | AT32F402CCU7     | 256KB       | QFN48    |                 |
| 0x7004_21D1 | AT32F402CBU7     | 128KB       | QFN48    |                 |
| 0x7005_3252 | AT32F402KCU7-4   | 256KB       | QFN32    |                 |
| 0x7004_21D3 | AT32F402KBU7-4   | 128KB       | QFN32    |                 |

## 25.4.2 DEBUG control register (DEBUG\_CTRL)

This register is asynchronously reset by POREST (not reset by system reset). It can be written by the debugger under reset.

| Bit      | Name            | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|-----------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:3 | Reserved        | 0x0000 0000 | resd | Always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 2    | STANDBY_DEBUG   | 0x0         | rw   | Debug Standby mode control bit<br>0: The whole 1.2V digital circuit is unpowered in Standby mode<br>1: The whole 1.2V digital circuit is not unpowered in Standby mode, and the system clock is provided by the internal RC oscillator (HICK)                                                                                                                                                                                                                                                                                                                                         |
| Bit 1    | DEEPSLEEP_DEBUG | 0x0         | rw   | Debug Deepsleep mode control bit<br>0: In Deepsleep mode, all clocks in the 1.2V domain are disabled. When exiting from Deepsleep mode, the internal RC oscillator (HICK) is enabled, and HICK is used as the system clock source, and the software must reprogram the system clock according to application requirements.<br>1: In Deepsleep mode, system clock is provided by the internal RC oscillator (HICK). When exiting from Deepsleep mode, HICK is used as the system clock source, and the software must reprogram the system clock according to application requirements. |
| Bit 0    | SLEEP_DEBUG     | 0x0         | rw   | Debug Sleep mode control bit<br>0: When entering Sleep mode, CPU HCLK clock is disabled, but other clocks remain active. When exiting from Sleep mode, it is not necessary to reprogram the clock system.<br>1: When entering Sleep mode, all clocks keep running.                                                                                                                                                                                                                                                                                                                    |

## 25.4.3 DEBUG APB1 pause register (DEBUG\_APB1\_PAUSE)

This register is asynchronously reset by POREST (not reset by system reset). It can be written by the debugger under reset.

| Bit        | Name               | Reset value | Type | Description                                                                                                                                                  |
|------------|--------------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 29 | Reserved           | 0x0         | resd | Kept at default value.                                                                                                                                       |
| Bit 28     | I2C3_SMBUS_TIMEOUT | 0x0         | rw   | I <sup>2</sup> C3 pause control bit<br>0: I <sup>2</sup> C3 SMBUS timeout control works normally<br>1: I <sup>2</sup> C3 SMBUS timeout control stops running |
| Bit 27     | I2C2_SMBUS_TIMEOUT | 0x0         | rw   | I <sup>2</sup> C2 pause control bit<br>0: I <sup>2</sup> C2 SMBUS timeout control works normally<br>1: I <sup>2</sup> C2 SMBUS timeout control stops running |
| Bit 26     | Reserved           | 0x0         | resd | Kept at default value.                                                                                                                                       |
| Bit 25     | CAN1_PAUSE         | 0x0         | rw   | CAN1 pause control bit<br>0: CAN1 works normally<br>1: CAN1 receive register pauses (does not receive data)                                                  |

|            |                    |      |      |                                                                                                                                                              |
|------------|--------------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 24     | I2C1_SMBUS_TIMEOUT | 0x0  | rw   | I <sup>2</sup> C1 pause control bit<br>0: I <sup>2</sup> C1 SMBUS timeout control works normally<br>1: I <sup>2</sup> C1 SMBUS timeout control stops running |
| Bit 23: 16 | Reserved           | 0x00 | resd | Kept at default value.                                                                                                                                       |
| Bit 15     | Reserved           | 0x0  | rw   | Kept at default value.                                                                                                                                       |
| Bit 14: 13 | Reserved           | 0x0  | rw   | Kept at default value.                                                                                                                                       |
| Bit 12     | WDT_PAUSE          | 0x0  | rw   | WDT pause control bit<br>0: WDT works normally<br>1: WDT stops running                                                                                       |
| Bit 11     | WWDT_PAUSE         | 0x0  | rw   | WWDT pause control bit<br>0: WWDT works normally<br>1: WWDT stops running                                                                                    |
| Bit 10     | ERTC_PAUSE         | 0x0  | rw   | ERTC pause control bit<br>0: ERTC works normally<br>1: ERTC stops running                                                                                    |
| Bit 9      | Reserved           | 0x0  | resd | Kept at default value.                                                                                                                                       |
| Bit 8      | TMR14_PAUSE        | 0x0  | rw   | TMR14 pause control bit<br>0: TMR14 works normally<br>1: TMR14 stops running                                                                                 |
| Bit 7      | TMR13_PAUSE        | 0x0  | rw   | TMR13 pause control bit<br>0: TMR13 works normally<br>1: TMR13 stops running                                                                                 |
| Bit 6      | Reserved           | 0x0  | resd | Kept at default value.                                                                                                                                       |
| Bit 5      | TMR7_PAUSE         | 0x0  | rw   | TMR7 pause control bit<br>0: TMR7 works normally<br>1: TMR7 stops running                                                                                    |
| Bit 4      | TMR6_PAUSE         | 0x0  | rw   | TMR6 pause control bit<br>0: TMR6 works normally<br>1: TMR6 stops running                                                                                    |
| Bit 3      | Reserved           | 0x0  | resd | Kept at default value.                                                                                                                                       |
| Bit 2      | TMR4_PAUSE         | 0x0  | rw   | TMR4 pause control bit<br>0: TMR4 works normally<br>1: TMR4 stops running                                                                                    |
| Bit 1      | TMR3_PAUSE         | 0x0  | rw   | TMR3 pause control bit<br>0: TMR3 works normally<br>1: TMR3 stops running                                                                                    |
| Bit 0      | TMR2_PAUSE         | 0x0  | rw   | TMR2 pause control bit<br>0: TMR2 works normally<br>1: TMR2 stops running                                                                                    |

## 25.4.4 DEBUG APB2 pause register (DEBUG\_APB2\_PAUSE)

This register is asynchronously reset by POREST (not reset by system reset). It can be written by the debugger under reset.

| Bit        | Name        | Reset value | Type | Description                                                                  |
|------------|-------------|-------------|------|------------------------------------------------------------------------------|
| Bit 31: 19 | Reserved    | 0x0000      | resd | Kept at default value.                                                       |
| Bit 18     | TMR11_PAUSE | 0x0         | rw   | TMR11 pause control bit<br>0: TMR11 works normally<br>1: TMR11 stops running |
| Bit 17     | TMR10_PAUSE | 0x0         | rw   | TMR10 pause control bit<br>0: TMR10 works normally<br>1: TMR10 stops running |
| Bit 16     | TMR9_PAUSE  | 0x0         | rw   | TMR9 pause control bit<br>0: TMR9 works normally<br>1: TMR9 stops running    |
| Bit 15: 1  | Reserved    | 0x0000      | resd | Kept at default value.                                                       |
| Bit 0      | TMR1_PAUSE  | 0x0         | rw   | TMR1 pause control bit<br>0: TMR1 works normally<br>1: TMR1 stops running    |

### 25.4.5 DEBUG SERIES ID register (DEBUG\_SER\_ID)

The DEBUG\_SER\_ID register identifies the ARTERY MCU part number and the version. It is mapped on the external PPB bus. This register is reset by PORESET asynchronously (not reset by system reset). This code is accessible using the SW debug port or by the user code.

| Bit        | Name     | Reset value | Type | Description                                               |
|------------|----------|-------------|------|-----------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at reset value                                       |
| Bit 15: 8  | SER_ID   | 0xXX        | ro   | MCU device identifier<br>AT32F402: 0x14<br>AT32F405: 0x13 |
| Bit 7: 3   | Reserved | 0x0000      | resd | Kept at reset value.                                      |
| Bit 2: 0   | REV_ID   | 0xX         | ro   | Revision identifier<br>0x0: Revision A                    |

## 26 Revision history

Document Revision History

| Date       | Version | Revision Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2023.08.31 | 2.00    | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2024.06.24 | 2.01    | <ul style="list-style-type: none"><li>1. Updated the description of <a href="#">Section 14.2.2 I2SF master clock sources</a></li><li>2. Updated the description of <a href="#">Section 19.1 ADC introduction</a></li><li>3. Updated Chapter 6 with the following:<ul style="list-style-type: none"><li>- Revised PC13 description in the second row to "Once enabled, PC13 pin acts as WKUP2 of PWC" in <a href="#">Table 6-6 of Section 6.2.11 IOMUX mapping priority</a></li><li>- Deleted "PA2, PC5, PB15" and their descriptions in <a href="#">Table 6-6 of Section 6.2.11 IOMUX mapping priority</a></li><li>- <a href="#">Table 6-2</a>: In "MUX1" column, revised PB14 description from to TMR1_CH2N to TMR1_CH2C</li><li>- <a href="#">Table 6-2</a>: In "MUX1" column, revised PB15 description from to TMR1_CH3N to TMR1_CH3C</li></ul></li><li>4. Updated "Memory" description in the summary page</li><li>5. Updated <a href="#">Figure 13-14 in Section 13.2.11 TI mode communication timings</a></li><li>6. Updated <a href="#">Figure 13-15 in Section 13.2.11 TI mode communication timings</a></li></ul> |
| 2025.06.02 | 2.02    | <ul style="list-style-type: none"><li>1. Updated 1.0V to 1.1V in the description of "Change LDO voltage to 1.1 V by setting the LDOOVSEL[1:0] bit" in <a href="#">Section 3.6 Power saving modes</a>:</li><li>2. Added <a href="#">Figure 13-7 in Section 13.2.5 CRC</a></li><li>3. Updated the description of the MDIV3EN bit [9] in <a href="#">Section 13.4.2 SPI control register 2 (SPI_CTRL2)</a></li><li>4. Updated <a href="#">Figure 15-3, Figure 15-15, Figure 15-44, Figure 15-69, Figure 15-92</a></li><li>5. Updated "Shift 1 bit" to "0xFF80" in "0xFFFF00" column, in <a href="#">Table 19-2, Section 19.4.4 Oversampling</a></li><li>6. Updated the ADCEN bit [0] description in <a href="#">Section 19.5.3 ADC control register 2 (ADC_CTRL2)</a></li><li>7. Added a "Note" description in <a href="#">Section 20.2 CAN main features</a></li><li>8. Updated the TMxEF bit description in <a href="#">Section 20.6.5 Message transmission</a></li><li>9. Updated the BYPASSC bit [0] description in <a href="#">Section 23.4.14 XIP command word 3 (XIP_CMD_W3)</a></li></ul>                             |

**IMPORTANT NOTICE – PLEASE READ CAREFULLY**

Purchasers are solely responsible for the selection and use of ARTERY's products and services, and ARTERY assumes no liability whatsoever relating to the choice, selection or use of the ARTERY products and services described herein.

No license, express or implied, to any intellectual property rights is granted under this document. If any part of this document deals with any third party products or services, it shall not be deemed a license granted by ARTERY for the use of such third party products or services, or any intellectual property contained therein, or considered as a warranty regarding the use in any manner of such third party products or services or any intellectual property contained therein.

Unless otherwise specified in ARTERY's terms and conditions of sale, ARTERY provides no warranties, express or implied, regarding the use and/or sale of ARTERY products, including but not limited to any implied warranties of merchantability, fitness for a particular purpose (and their equivalents under the laws of any jurisdiction), or infringement on any patent, copyright or other intellectual property right.

Purchasers hereby agree that ARTERY's products are not designed or authorized for use in: (A) any application with special requirements of safety such as life support and active implantable device, or system with functional safety requirements; (B) any aircraft application; (C) any aerospace application or environment; (D) any weapon application, and/or (E) or other uses where the failure of the device or product could result in personal injury, death, property damage. Purchasers' unauthorized use of them in the aforementioned applications, even if with a written notice, is solely at purchasers' risk, and Purchasers are solely responsible for meeting all legal and regulatory requirements in such use.

Resale of ARTERY products with provisions different from the statements and/or technical characteristics stated in this document shall immediately void any warranty grant by ARTERY for ARTERY's products or services described herein and shall not create or expand any liability of ARTERY in any manner whatsoever.

© 2025 ARTERY Technology - All Rights Reserved.