

## ARM®-based 32-bit Cortex®-M4F MCU+FPU with 256 to 4032 KB Flash, sLib, dual QSPI, SDRAM, dual OTGFS, Ethernet, camera, 18 timers, 3 ADCs, 23 communication interfaces

### Feature

- **Core: ARM®32-bit Cortex®-M4F CPU with FPU**
  - 288 MHz maximum frequency, with a Memory Protection Unit (MPU), single-cycle multiplication and hardware division
  - Floating Point Unit (FPU)
  - DSP instructions
- **Memories**
  - 256 to 4032 KBytes of Flash memory
  - sLib: configurable part of main Flash set as a library area with code executable but secured, non-readable
  - 384 to 512 KBytes of SRAM
  - External memory controller (XMC) with 16-bit data bus: supports CF, SRAM, PSRAM, NOR, NAND, SDRAM memories
  - Up to 2 x QSPI interfaces for external SPI Flash or SPI RAM extension, and memory mapping mode
- **LCD parallel interface, 8080/6800 modes**
- **Power control (PWC)**
  - 2.6 V ~ 3.6 V application supply
  - Power-on reset (POR)/ low voltage reset (LVR), and power voltage monitor (PVM)
  - Low power: Sleep, Deepsleep, and Standby modes
  - VBAT supply for LEXT, ERTC and 20 x 32-bit battery power register (ERTC\_BPR)
- **Clock and reset management (CRM)**
  - 4 to 25 MHz crystal oscillator (HEXT)
  - Internal 48 MHz factory-trimmed clock (HICK), accuracy  $\pm 1\%$  at  $T_A=25^\circ\text{C}$ ,  $\pm 2.5\%$  at  $T_A=-40$  to  $+105^\circ\text{C}$ , with automatic clock calibration (ACC)
  - PLL with configurable frequency multiplication and division factor
  - 32.768 kHz crystal oscillator (LEXT)
  - Internal low speed RC oscillator (LICK)
- **Analog**
  - 3 x 12-bit 5.33 MSPS A/D converters, up to 24 input channels, 12-bit/10-bit/8-bit/6-bit configurable resolution, hardware oversampling up to equivalent 16-bit resolution
  - Temperature sensor ( $V_{TS}$ ), internal reference voltage ( $V_{INTR}$ ),  $V_{BAT}$  battery voltage monitor ( $V_{BAT}/4$ )
  - 2 x 12-bit D/A converters
- **DMA:**
  - 2 x general-purpose DMAs and 1 x EDMA
  - 22 channels in all
- **Up to 116 Fast I/O Interfaces**
- All mappable to 16 external interrupt vectors
- Almost 5 V-tolerant
- **Up to 18 Timers (TMR)**
  - Up to 13 x 16-bit timers + 2 x 32-bit timers, each with 4 IC/OC/PWM or pulse counter channels
  - 2 x Watchdog timers (WDT and WWDT)
  - SysTick timer: 24-bit downcounter
- **ERTC: enhanced RTC with auto wakeup, alarm, subsecond precision, hardware calendar and calibration feature**
- **Up to 23 communication interfaces**
  - Up to 3 x I<sup>2</sup>C interfaces (SMBus/PMBus)
  - Up to 4 x USARTs/4 x UARTs (ISO7816 interface, LIN, IrDA capability, modem control and RS485 drive enable, with interchangeable TX/RX)
  - Up to 4 x SPIs (36 Mbit/s), all with I<sup>2</sup>S interface multiplexed, I<sup>2</sup>S2/ I<sup>2</sup>S3 support full-duplex
  - Up to 2 x CAN interfaces (2.0B Active)
  - Up to 2 x OTG FS controllers supporting crystal-less
  - Up to 2 x SDIO interfaces
  - Infrared transmitter (IRTMR)
  - 10/100M Ethernet MAC with dedicated DMA and SRAM(4 Kbytes): IEEE1588 hardware support, MII/RMII available (For AT32F437 only)
- **8-14 bit parallel digital camera interface (DVP)**
- **CRC Calculation Unit**
- **96-bit ID (UID)**
- **Debug mode**
  - SWD and JTAG interfaces
- **Temperature range: -40 to 105 °C**
- **Packaging**
  - LQFP144 20 x 20 mm LQFP100 14 x 14 mm
  - LQFP64 10 x 10 mm LQFP48 7 x 7 mm
  - QFN48 6 x 6 mm
- **List of Models**

| Internal Flash | Model                                                                                                          |
|----------------|----------------------------------------------------------------------------------------------------------------|
| 4032 KBytes    | AT32F435ZMT7, AT32F435VMT7, AT32F435RMT7, AT32F435CMT7, AT32F435CMU7, AT32F437ZMT7, AT32F437VMT7, AT32F437RMT7 |
| 1024 KBytes    | AT32F435ZGT7, AT32F435VGT7, AT32F435RGT7, AT32F435CGT7, AT32F435CGU7, AT32F437ZGT7, AT32F437VGT7, AT32F437RGT7 |
| 448 KBytes     | AT32F435ZDT7, AT32F435VDT7, AT32F435RDT7, AT32F435CDT7, AT32F435CDU7, AT32F437ZDT7, AT32F437VDT7, AT32F437RDT7 |
| 256 KBytes     | AT32F435ZCT7, AT32F435VCT7, AT32F435RCT7, AT32F435CCT7, AT32F435CCU7, AT32F437ZCT7, AT32F437VCT7, AT32F437RCT7 |

## Contents

|          |                                                     |           |
|----------|-----------------------------------------------------|-----------|
| <b>1</b> | <b>System architecture .....</b>                    | <b>44</b> |
| 1.1      | System overview.....                                | 46        |
| 1.1.1    | ARM Cortex®-M4F processor .....                     | 46        |
| 1.1.2    | BusMatrix .....                                     | 46        |
| 1.1.3    | Bit band .....                                      | 48        |
| 1.1.4    | Interrupt and exception vectors .....               | 50        |
| 1.1.5    | System Tick (SysTick) .....                         | 53        |
| 1.1.6    | Reset .....                                         | 54        |
| 1.2      | List of abbreviations for registers .....           | 56        |
| 1.3      | Device characteristics information .....            | 56        |
| 1.3.1    | Flash memory size register .....                    | 56        |
| 1.3.2    | Device electronic signature .....                   | 56        |
| <b>2</b> | <b>Memory resources .....</b>                       | <b>57</b> |
| 2.1      | Internal memory address map .....                   | 57        |
| 2.2      | Flash memory.....                                   | 57        |
| 2.3      | SRAM memory.....                                    | 60        |
| 2.4      | Peripheral address map.....                         | 60        |
| <b>3</b> | <b>Power control (PWC).....</b>                     | <b>63</b> |
| 3.1      | Introduction .....                                  | 63        |
| 3.2      | Main Features .....                                 | 63        |
| 3.3      | POR/LVR .....                                       | 63        |
| 3.4      | Power voltage monitor (PVM).....                    | 64        |
| 3.5      | Power domain.....                                   | 64        |
| 3.6      | Power saving modes .....                            | 65        |
| 3.7      | PWC registers .....                                 | 67        |
| 3.7.1    | Power control register (PWC_CTRL) .....             | 68        |
| 3.7.2    | Power control/status register (PWC_CTRLSTS) .....   | 68        |
| 3.7.3    | LDO output voltage select register (PWC_LDOOV)..... | 69        |
| <b>4</b> | <b>Clock and reset manage (CRM).....</b>            | <b>70</b> |

|                                                                                       |    |
|---------------------------------------------------------------------------------------|----|
| 4.1 Clock .....                                                                       | 70 |
| 4.1.1 Clock sources .....                                                             | 70 |
| 4.1.2 System clock.....                                                               | 71 |
| 4.1.3 Peripheral clock .....                                                          | 71 |
| 4.1.4 Clock fail detector .....                                                       | 72 |
| 4.1.5 Auto step-by-step system clock switch.....                                      | 72 |
| 4.1.6 Clock output.....                                                               | 72 |
| 4.1.7 Interrupts.....                                                                 | 72 |
| 4.2 Reset.....                                                                        | 72 |
| 4.2.1 System reset.....                                                               | 72 |
| 4.2.2 Battery powered domain reset.....                                               | 73 |
| 4.3 CRM registers .....                                                               | 73 |
| 4.3.1 Clock control register (CRM_CTRL).....                                          | 74 |
| 4.3.2 PLL clock configuration register (CRM_PLLCFG) .....                             | 75 |
| 4.3.3 Clock configuration register (CRM_CFG) .....                                    | 76 |
| 4.3.4 Clock interrupt register (CRM_CLKINT) .....                                     | 78 |
| 4.3.5 APB peripheral reset register 1 (CRM_APBRST1) .....                             | 79 |
| 4.3.6 APB peripheral reset register 2 (CRM_APBRST2) .....                             | 80 |
| 4.3.7 APB peripheral reset register 3 (CRM_APBRST3) .....                             | 80 |
| 4.3.8 APB1 peripheral reset register (CRM_APB1RST) .....                              | 81 |
| 4.3.9 APB2 peripheral reset register (CRM_APB2RST) .....                              | 82 |
| 4.3.10 APB peripheral clock enable register 1 (CRM_AHBEN1) .....                      | 83 |
| 4.3.11 APB peripheral clock enable register 2 (CRM_AHBEN2) .....                      | 84 |
| 4.3.12 APB1 peripheral clock enable register 3 (CRM_AHBLPEN1) .....                   | 84 |
| 4.3.13 APB1 peripheral clock enable register (CRM_APB1EN) .....                       | 85 |
| 4.3.14 APB2 peripheral clock enable register (CRM_AHBLPEN2) .....                     | 86 |
| 4.3.15 APB peripheral clock enable in low power mode register1<br>(CRM_AHBLPEN1)..... | 87 |
| 4.3.16 APB peripheral clock enable in low power mode register2<br>(CRM_AHBLPEN2)..... | 89 |
| 4.3.17 APB peripheral clock enable in low power mode register3<br>(CRM_AHBLPEN3)..... | 89 |
| 4.3.18 APB1 peripheral clock enable in low power mode register<br>(CRM_AHBLPEN).....  | 89 |

|                                                                                    |           |
|------------------------------------------------------------------------------------|-----------|
| 4.3.19 APB2 peripheral clock enable in low power mode register (CRM_AHB2LPEN)..... | 91        |
| 4.3.20 Battery powered domain control register (CRM_BPDC).....                     | 92        |
| 4.3.21 Control/status register (CRM_CTRLSTS) .....                                 | 92        |
| 4.3.22 Additional register 1 (CRM_MISC1) .....                                     | 93        |
| 4.3.23 Additional register 2 (CRM_MISC2) .....                                     | 94        |
| <b>5     Flash memory controller (FLASH) .....</b>                                 | <b>96</b> |
| 5.1    FLASH introduction .....                                                    | 96        |
| 5.2    Flash memory operation .....                                                | 102       |
| 5.2.1    Unlock/lock .....                                                         | 102       |
| 5.2.2    Erase operation.....                                                      | 102       |
| 5.2.3    Programming operation.....                                                | 105       |
| 5.2.4    Read operation .....                                                      | 106       |
| 5.3    User system data area operation.....                                        | 106       |
| 5.3.1    Unlock/lock .....                                                         | 106       |
| 5.3.2    Erase operation.....                                                      | 107       |
| 5.3.3    Programming operation.....                                                | 108       |
| 5.3.4    Read operation .....                                                      | 109       |
| 5.4    Flash memory protection .....                                               | 109       |
| 5.4.1    Access protection.....                                                    | 109       |
| 5.4.2    Erase/program protection.....                                             | 109       |
| 5.5    Special functions .....                                                     | 109       |
| 5.5.1    Security library settings .....                                           | 109       |
| 5.5.2    CRC calculation unit.....                                                 | 111       |
| 5.6    Flash memory registers .....                                                | 111       |
| 5.6.1    Flash performance select register (FLASH_PSR) .....                       | 112       |
| 5.6.2    Flash unlock register (FLASH_UNLOCK) .....                                | 112       |
| 5.6.3    Flash user system data unlock register (FLASH_USD_UNLOCK) ..              | 112       |
| 5.6.4    Flash status register (FLASH_STS) .....                                   | 112       |
| 5.6.5    Flash control register (FLASH_CTRL).....                                  | 113       |
| 5.6.6    Flash address register (FLASH_ADDR) .....                                 | 113       |
| 5.6.7    User system data register (FLASH_USD).....                                | 113       |
| 5.6.8    Erase/program protection status register 0 (FLASH_EPPS0).....             | 114       |
| 5.6.9    Erase/program protection status register 1 (FLASH_EPPS1).....             | 114       |

|                                                                         |            |
|-------------------------------------------------------------------------|------------|
| 5.6.10 Flash unlock register 2 (FLASH_UNLOCK2).....                     | 114        |
| 5.6.11 Flash status register 2 (FLASH_STS2) .....                       | 114        |
| 5.6.12 Flash control register 2 (FLASH_CTRL2) .....                     | 115        |
| 5.6.13 Flash address register 2 (FLASH_ADDR2).....                      | 115        |
| 5.6.14 Flash continue read register (FLASH_CONTR).....                  | 115        |
| 5.6.15 Flash divider register (FLASH_DIVR) .....                        | 116        |
| 5.6.16 Flash security library status register 2 (SLIB_STS2).....        | 116        |
| 5.6.17 Flash security library status register 0 (SLIB_STS0).....        | 116        |
| 5.6.18 Flash security library status register 1 (SLIB_STS1).....        | 116        |
| 5.6.19 Flash security library password clear register (SLIB_PWD_CLR)... | 117        |
| 5.6.20 Security library additional status register (SLIB_MISC_STS)..... | 117        |
| 5.6.21 Security library password setting register (SLIB_SET_PWD).....   | 117        |
| 5.6.22 Security library address setting register0 (SLIB_SET_RANGE0) ... | 117        |
| 5.6.23 Security library address setting register 1 (SLIB_SET_RANGE1) .. | 118        |
| 5.6.24 Security library unlock register (SLIB_UNLOCK) .....             | 118        |
| 5.6.25 Flash CRC calibration control register (FLASH_CRC_CTRL).....     | 118        |
| 5.6.26 Flash CRC check result register (FLASH_CRC_CHK).....             | 119        |
| <b>6      GPIOs and IOMUX .....</b>                                     | <b>120</b> |
| 6.1     Introduction .....                                              | 120        |
| 6.2     Function overview .....                                         | 120        |
| 6.2.1    GPIO structure .....                                           | 120        |
| 6.2.2    GPIO reset status.....                                         | 120        |
| 6.2.3    General-purpose input configuration.....                       | 121        |
| 6.2.4    Analog mode configuration.....                                 | 121        |
| 6.2.5    General-purpose output configuration.....                      | 121        |
| 6.2.6    I/O port write protection .....                                | 122        |
| 6.2.7    IOMUX structure .....                                          | 122        |
| 6.2.8    Multiplexed function configuration .....                       | 123        |
| 6.2.9    IOMUX input/output .....                                       | 124        |
| 6.2.10 Peripheral MUX function configuration .....                      | 138        |
| 6.2.11 IOMUX map priority .....                                         | 138        |
| 6.2.12 External interrupt/wake-up lines .....                           | 139        |
| 6.3     GPIO registers.....                                             | 139        |
| 6.3.1    GPIO configuration register (GPIOx_CFGR) (x=A..H) .....        | 139        |

|          |                                                                          |            |
|----------|--------------------------------------------------------------------------|------------|
| 6.3.2    | GPIO output mode register (GPIOx_OMODE) (x=A..H) .....                   | 139        |
| 6.3.3    | GPIO drive capability register (GPIOx_ODRVR) (x=A..H) .....              | 140        |
| 6.3.4    | GPIO pull-up/pull-down register (GPIOx_PULL) (x=A..H) .....              | 140        |
| 6.3.5    | GPIO input register (GPIOx_IDH) (x=A..H).....                            | 140        |
| 6.3.6    | GPIO output register (GPIOx_IDH) (x=A..H).....                           | 140        |
| 6.3.7    | GPIO set/clear register (GPIOx_SCR) (x=A..H) .....                       | 140        |
| 6.3.8    | GPIO write protection register (GPIOx_WPR) (x=A..H) .....                | 141        |
| 6.3.9    | GPIO multiplexed function low register (GPIOx_MUXL) (x=A..H) ...         | 141        |
| 6.3.10   | GPIO multiplexed function high register (GPIOx_MUXH) (x=A..H) .          | 142        |
| 6.3.11   | GPIO port bit clear register (GPIOx_CLR) (x=A..H) .....                  | 142        |
| 6.3.12   | GPIO huge current control register (GPIOx_HDRV) (x=A..E) .....           | 142        |
| <b>7</b> | <b>System configuration controller (SCFG)</b> .....                      | <b>143</b> |
| 7.1      | Introduction .....                                                       | 143        |
| 7.2      | IOMUX registers .....                                                    | 143        |
| 7.2.1    | SCFG configuration register 1 (SCFG_CFG1) .....                          | 143        |
| 7.2.2    | SCFG configuration register 2 (SCFG_CFG2) .....                          | 144        |
| 7.2.3    | SCFG external interrupt configuration register 1<br>(SCFG_EXINTC1) ..... | 144        |
| 7.2.4    | SCFG external interrupt configuration register 2<br>(SCFG_EXINTC2) ..... | 145        |
| 7.2.5    | SCFG external interrupt configuration register 3<br>(SCFG_EXINTC3) ..... | 146        |
| 7.2.6    | SCFG external interrupt configuration register 4<br>(SCFG_EXINTC4) ..... | 147        |
| 7.2.7    | SCFG ultra high sourcing/sinking strength (SCFG_UHDRV) .....             | 149        |
| <b>8</b> | <b>External interrupt/Event controller (EXINT)</b> .....                 | <b>151</b> |
| 8.1      | EXINT introduction.....                                                  | 151        |
| 8.2      | Function overview and configuration procedure .....                      | 151        |
| 8.3      | EXINT registers .....                                                    | 152        |
| 8.3.1    | Interrupt enable register (EXINT_INTEN) .....                            | 152        |
| 8.3.2    | Event enable register (EXINT_EVTEN) .....                                | 152        |
| 8.3.3    | Polarity configuration register 1 (EXINT_POLCFG1) .....                  | 152        |
| 8.3.4    | Polarity configuration register 2 (EXINT_POLCFG2) .....                  | 153        |
| 8.3.5    | Software trigger register (EXINT_SWTRG).....                             | 153        |

|                                                                                    |            |
|------------------------------------------------------------------------------------|------------|
| 8.3.6 Interrupt status register (EXINT_INTSTS) .....                               | 153        |
| <b>9 DMA controller (DMA) .....</b>                                                | <b>154</b> |
| 9.1 Introduction .....                                                             | 154        |
| 9.2 Main features .....                                                            | 154        |
| 9.3 Function overview .....                                                        | 155        |
| 9.3.1 DMA configuration.....                                                       | 155        |
| 9.3.2 Handshake mechanism.....                                                     | 155        |
| 9.3.3 Arbiter .....                                                                | 156        |
| 9.3.4 Programmable data transfer width .....                                       | 156        |
| 9.3.5 Errors .....                                                                 | 157        |
| 9.3.6 Interrupts .....                                                             | 157        |
| 9.4 DMA multiplexer (DMAMUX) .....                                                 | 157        |
| 9.4.1 DMAMUX functional overview .....                                             | 158        |
| 9.4.2 DMAMUX overflow interrupts .....                                             | 160        |
| 9.5 DMA registers.....                                                             | 161        |
| 9.5.1 DMA interrupt status register (DMA_STS) .....                                | 162        |
| 9.5.2 DMA interrupt flag clear register (DMA_CLR) .....                            | 164        |
| 9.5.3 DMA channel-x configuration register (DMA_CxCTRL)     (x = 1...7)            | 166        |
| 9.5.4 DMA channel-x number of data register (DMA_CxDTCNT) (x = 1...7)              | 167        |
| 9.5.5 DMA channel-x peripheral address register (DMA_CxPADDR)<br>(x = 1...7) ..... | 167        |
| 9.5.6 DMA channel-x memory address register (DMA_CxMADDR)<br>(x = 1...7) .....     | 167        |
| 9.5.7 DMAMUX selection register (DMA_MUXSEL) .....                                 | 167        |
| 9.5.8 DMAMUX channel-x control register (DMA_MUXCxCTRL) (x = 1...7)                | 167        |
| 9.5.9 DMAMUX generator x control register (DMA_MUXGxCTRL) (x = 1...4)              | 168        |
| 9.5.10 DMAMUX channel synchronization status register<br>(DMA_MUXSYNCSTS) .....    | 169        |
| 9.5.11 DMAMUX channel interrupt clear flag register (DMA_MUXSYNCCCLR)              | 169        |
| 9.5.12 DMAMUX generator interrupt status register (DMA_MUXGSTS) ...                | 169        |
| 9.5.13 DMAMUX generator interrupt flag clear register (DMA_MUXGCLR)                | 170        |
| <b>10 CRC calculation unit (CRC).....</b>                                          | <b>171</b> |
| 10.1 CRC introduction .....                                                        | 171        |

|                                                         |            |
|---------------------------------------------------------|------------|
| 10.2 CRC function description .....                     | 171        |
| 10.3 CRC registers.....                                 | 172        |
| 10.3.1 Data register (CRC_DT).....                      | 172        |
| 10.3.2 Common data register (CRC_CDT).....              | 172        |
| 10.3.3 Control register (CRC_CTRL).....                 | 173        |
| 10.3.4 Initialization register (CRC_IDT) .....          | 173        |
| 10.3.5 Polynomial register (CRC_POLY) .....             | 173        |
| <b>11 I<sup>2</sup>C interface .....</b>                | <b>174</b> |
| 11.1 I <sup>2</sup> C introduction.....                 | 174        |
| 11.2 I <sup>2</sup> C main features .....               | 174        |
| 11.3 I <sup>2</sup> C function overview .....           | 174        |
| 11.4 I <sup>2</sup> C interface .....                   | 175        |
| 11.4.1 I <sup>2</sup> C timing control .....            | 177        |
| 11.4.2 Data transfer management.....                    | 178        |
| 11.4.3 I <sup>2</sup> C master communication flow ..... | 179        |
| 11.4.4 I <sup>2</sup> C slave communication flow.....   | 184        |
| 11.4.5 SMBus.....                                       | 188        |
| 11.4.6 SMBus master communication flow.....             | 190        |
| 11.4.7 SMBus slave communication flow.....              | 194        |
| 11.4.8 Data transfer using DMA.....                     | 198        |
| 11.4.9 Error management.....                            | 198        |
| 11.5 I <sup>2</sup> C interrupt requests .....          | 200        |
| 11.6 I <sup>2</sup> C debug mode .....                  | 200        |
| 11.7 I <sup>2</sup> C registers .....                   | 200        |
| 11.7.1 Control register 1 (I2C_CTRL1).....              | 201        |
| 11.7.2 Control register 2 (I2C_CTRL2).....              | 202        |
| 11.7.3 Address register 1 (I2C_OADDR1) .....            | 203        |
| 11.7.4 Own address register 2 (I2C_OADDR2) .....        | 203        |
| 11.7.5 Timing register (I2C_CLKCTRL).....               | 203        |
| 11.7.6 Timeout register (I2C_TIMEOUT) .....             | 203        |
| 11.7.7 Status register (I2C_STS) .....                  | 204        |
| 11.7.8 Status clear register (I2C_CLR) .....            | 205        |
| 11.7.9 PEC register (I2C_PEC) .....                     | 206        |
| 11.7.10 Receive data register (I2C_RXDT).....           | 206        |

|                                                                                |            |
|--------------------------------------------------------------------------------|------------|
| 11.7.11 Transmit data register (I2C_TXDT) .....                                | 206        |
| <b>12 Universal synchronous/asynchronous receiver/transmitter (USART).....</b> | <b>207</b> |
| 12.1 USART introduction .....                                                  | 207        |
| 12.2 Full-duplex/half-duplex selector .....                                    | 209        |
| 12.3 Mode selector.....                                                        | 209        |
| 12.3.1 Introduction.....                                                       | 209        |
| 12.3.2 Configuration procedure .....                                           | 209        |
| 12.4 USART frame format and configuration.....                                 | 212        |
| 12.5 DMA transfer introduction .....                                           | 214        |
| 12.5.1 Transmission using DMA .....                                            | 214        |
| 12.5.2 Reception using DMA .....                                               | 214        |
| 12.6 Baud rate generation.....                                                 | 215        |
| 12.6.1 Introduction.....                                                       | 215        |
| 12.6.2 Configuration .....                                                     | 215        |
| 12.7 Transmitter.....                                                          | 216        |
| 12.7.1 Transmitter introduction .....                                          | 216        |
| 12.7.2 Transmitter configuration .....                                         | 216        |
| 12.8 Receiver .....                                                            | 217        |
| 12.8.1 Receiver introduction.....                                              | 217        |
| 12.8.2 Receiver configuration .....                                            | 217        |
| 12.8.3 Start bit and noise detection .....                                     | 218        |
| 12.9 Tx/Rx swap .....                                                          | 219        |
| 12.10 Interrupt requests .....                                                 | 219        |
| 12.11 I/O pin control.....                                                     | 220        |
| 12.12 USART registers.....                                                     | 221        |
| 12.12.1 Status register (USART_STS) .....                                      | 221        |
| 12.12.2 Data register (USART_DT) .....                                         | 222        |
| 12.12.3 Baud rate register (USART_BAUDR) .....                                 | 222        |
| 12.12.4 Control register 1 (USART_CTRL1) .....                                 | 222        |
| 12.12.5 Control register 2 (USART_CTRL2) .....                                 | 224        |
| 12.12.6 Control register 3 (USART_CTRL3) .....                                 | 225        |
| 12.12.7 Guard time and divider register (USART_GDIV) .....                     | 226        |
| <b>13 Serial peripheral interface (SPI).....</b>                               | <b>227</b> |

|                                                                                     |     |
|-------------------------------------------------------------------------------------|-----|
| 13.1 SPI introduction .....                                                         | 227 |
| 13.2 Function overview .....                                                        | 227 |
| 13.2.1 SPI description.....                                                         | 227 |
| 13.2.2 Full-duplex/half-duplex selector .....                                       | 229 |
| 13.2.3 Chip select controller.....                                                  | 230 |
| 13.2.4 SPI_SCK controller .....                                                     | 231 |
| 13.2.5 CRC .....                                                                    | 231 |
| 13.2.6 DMA transfer.....                                                            | 232 |
| 13.2.7 TI mode .....                                                                | 233 |
| 13.2.8 Transmitter .....                                                            | 233 |
| 13.2.9 Receiver .....                                                               | 233 |
| 13.2.10 Motorola mode .....                                                         | 234 |
| 13.2.11 TI mode .....                                                               | 236 |
| 13.2.12 Interrupts .....                                                            | 237 |
| 13.2.13 IO pin control .....                                                        | 238 |
| 13.2.14 Precautions.....                                                            | 238 |
| 13.3 I <sup>2</sup> S functional description .....                                  | 238 |
| 13.3.1 I <sup>2</sup> S introduction .....                                          | 238 |
| 13.3.2 I <sup>2</sup> S full-duplex .....                                           | 239 |
| 13.3.3 Operating mode selector.....                                                 | 239 |
| 13.3.4 Audio protocol selector.....                                                 | 241 |
| 13.3.5 I2S_CLK controller .....                                                     | 242 |
| 13.3.6 DMA transfer.....                                                            | 244 |
| 13.3.7 Transmitter/Receiver .....                                                   | 245 |
| 13.3.8 I <sup>2</sup> S communication timings .....                                 | 245 |
| 13.3.9 Interrupts .....                                                             | 246 |
| 13.3.10 IO pin control .....                                                        | 246 |
| 13.4 SPI registers .....                                                            | 247 |
| 13.4.1 SPI control register 1 (SPI_CTRL1) (Not used in I <sup>2</sup> S mode) ..... | 247 |
| 13.4.2 SPI control register 2 (SPI_CTRL2) .....                                     | 248 |
| 13.4.3 SPI status register (SPI_STS).....                                           | 249 |
| 13.4.4 SPI data register (SPI_DT) .....                                             | 250 |
| 13.4.5 SPICRC register (SPI_CPOLY) (Not used in I <sup>2</sup> S mode).....         | 250 |
| 13.4.6 SPIRxCRC register (SPI_RCRC) (Not used in I <sup>2</sup> S mode) .....       | 250 |
| 13.4.7 SPITxCRC register (SPI_TCRC).....                                            | 250 |

|                                                                       |            |
|-----------------------------------------------------------------------|------------|
| 13.4.8 SPI_I2S register (SPI_I2SCTRL) .....                           | 250        |
| 13.4.9 SPI_I2S prescaler register (SPI_I2SCLKP) .....                 | 251        |
| <b>14 Timer .....</b>                                                 | <b>252</b> |
| 14.1 Basic timer (TMR6 and TMR7) .....                                | 253        |
| 14.1.1 TMR6 and TMR7 introduction .....                               | 253        |
| 14.1.2 TMR6 and TMR7 main features .....                              | 253        |
| 14.1.3 TMR6 and TMR7 function overview .....                          | 253        |
| 14.1.3.1 Counting clock.....                                          | 253        |
| 14.1.3.2 Counting mode .....                                          | 253        |
| 14.1.3.3 Debug mode .....                                             | 255        |
| 14.1.4 TMR6 and TMR7 registers .....                                  | 255        |
| 14.1.4.1 TMR6 and TMR7 control register 1 (TMRx_CTRL1).....           | 255        |
| 14.1.4.2 TMR6 and TMR7 control register 2 (TMRx_CTRL2).....           | 256        |
| 14.1.4.3 TMR6 and TMR7 DMA/interrupt enable register (TMRx_IDEN) ..   | 256        |
| 14.1.4.4 TMR6 and TMR7 interrupt status register (TMRxISTS) .....     | 256        |
| 14.1.4.5 TMR6 and TMR7 software event register (TMRx_SWEVT).....      | 256        |
| 14.1.4.6 TMR6 and TMR7 counter value (TMRx_CVAL) .....                | 256        |
| 14.1.4.7 TMR6 and TMR7 division (TMRx_DIV) .....                      | 257        |
| 14.1.4.8 TMR6 and TMR7 period register (TMRx_PR) .....                | 257        |
| 14.2 General-purpose timer (TMR2 to TMR5) .....                       | 257        |
| 14.2.1 TMR2 to TMR5 introduction .....                                | 257        |
| 14.2.2 TMR2 to TMR5 main features.....                                | 257        |
| 14.2.3 TMR2 to TMR5 functional overview .....                         | 258        |
| 14.2.3.1 Counting clock.....                                          | 258        |
| 14.2.3.2 Counting mode .....                                          | 261        |
| 14.2.3.3 TMR input function.....                                      | 263        |
| 14.2.3.4 TMR output function.....                                     | 266        |
| 14.2.3.5 TMR synchronization.....                                     | 269        |
| 14.2.3.6 Debug mode .....                                             | 272        |
| 14.2.4 TMRx registers.....                                            | 272        |
| 14.2.4.1 TMR2 to TMR5 control register 1 (TMRx_CTRL1) .....           | 273        |
| 14.2.4.2 TMR2 to TMR5 control register 2 (TMRx_CTRL2) .....           | 274        |
| 14.2.4.3 TMR2 to TMR5 slave timer control register (TMRx_STCTRL) .... | 274        |
| 14.2.4.4 TMR2 to TMR5 DMA/interrupt enable register (TMRx_IDEN) ....  | 275        |
| 14.2.4.5 TMR2 to TMR5 interrupt status register (TMRxISTS) .....      | 276        |
| 14.2.4.6 TMR2 to TMR5 software event register (TMRx_SWEVT) .....      | 277        |

|                                                                     |            |
|---------------------------------------------------------------------|------------|
| 14.2.4.7 TMR2 to TMR5 channel mode register 1 (TMRx_CM1) .....      | 277        |
| 14.2.4.8 TMR2 to TMR5 channel mode register 2 (TMRx_CM2) .....      | 279        |
| 14.2.4.9 TMR2 to TMR5 channel control register (TMRx_CCTRL) .....   | 280        |
| 14.2.4.10 TMR2 to TMR5 counter value (TMRx_CVAL) .....              | 281        |
| 14.2.4.11 TMR2 to TMR5 division value (TMRx_DIV) .....              | 281        |
| 14.2.4.12 TMR2 to TMR5 period register (TMRx_PR) .....              | 281        |
| 14.2.4.13 TMR2 to TMR5 channel 1 data register (TMRx_C1DT) .....    | 281        |
| 14.2.4.14 TMR2 to TMR5 channel 2 data register (TMRx_C2DT) .....    | 281        |
| 14.2.4.15 TMR2 to TMR5 channel 3 data register (TMRx_C3DT) .....    | 282        |
| 14.2.4.16 TMR2 to TMR5 channel 4 data register (TMRx_C4DT) .....    | 282        |
| 14.2.4.17 TMR2 to TMR5 DMA control register (TMRx_DMACTRL) .....    | 282        |
| 14.2.4.18 TMR2 to TMR5 DMA data register (TMRx_DMADT) .....         | 282        |
| 14.2.4.19 TMR5 channel input remapping register (TMR2_RMP) .....    | 283        |
| 14.2.4.20 TMR2 channel input remapping register (TMR5_RMP) .....    | 283        |
| <b>14.3 General-purpose timer (TMR9 to TMR14) .....</b>             | <b>283</b> |
| 14.3.1 TMR9 to TMR14 introduction.....                              | 283        |
| 14.3.2 TMR9 to TMR14 main features .....                            | 283        |
| 14.3.2.1 TMR9 and TMR12 main features .....                         | 283        |
| 14.3.2.2 TMR10, TMR11, TMR13 and TMR14 main features .....          | 284        |
| 14.3.3 TMR9 to TMR14 functional overview .....                      | 284        |
| 14.3.3.1 Counting clock.....                                        | 284        |
| 14.3.3.2 Counting mode .....                                        | 287        |
| 14.3.3.3 TMR input function.....                                    | 288        |
| 14.3.3.4 TMR output function.....                                   | 290        |
| 14.3.3.5 TMR synchronization.....                                   | 292        |
| 14.3.3.6 Debug mode .....                                           | 293        |
| 14.3.4 TMR9 and TMR12 registers .....                               | 293        |
| 14.3.4.1 TMR9 and TMR12 control register 1 (TMRx_CTRL1).....        | 293        |
| 14.3.4.2 TMR9 and TMR12 slave timer control register (TMRx_STCTRL)  | 294        |
| 14.3.4.3 TMR9 and TMR12 DMA/interrupt enable register (TMRx_IDEN)   | 294        |
| 14.3.4.4 TMR9 and TMR12 interrupt status register (TMRxISTS) .....  | 295        |
| 14.3.4.5 TMR9 and TMR12 software event register (TMRx_SWEVT) .....  | 295        |
| 14.3.4.6 TMR9 and TMR12 channel mode register1 (TMRx_CM1) .....     | 296        |
| 14.3.4.7 TMR9 and TMR12 channel control register (TMRx_CCTRL) ..... | 298        |
| 14.3.4.8 TMR9 and TMR12 counter value (TMRx_CVAL) .....             | 298        |
| 14.3.4.9 TMR9 and TMR12 division value (TMRx_DIV) .....             | 298        |
| 14.3.4.10 TMR9 and TMR12 period register (TMRx_PR) .....            | 298        |
| 14.3.4.11 TMR9 and TMR12 channel 1 data register (TMRx_C1DT) .....  | 298        |

|                                                                                           |     |
|-------------------------------------------------------------------------------------------|-----|
| 14.3.4.12 TMR9 and TMR12 channel 2 data register (TMRx_C2DT) .....                        | 299 |
| 14.3.5 TMR10, TMR11, TMR13 and TMR14 registers.....                                       | 299 |
| 14.3.5.1 TMR10, TMR11, TMR13 and TMR14 control register 1<br>(TMRx_CTRL1).....            | 299 |
| 14.3.5.2 TMR10, TMR11, TMR13 and TMR14 DMA/interrupt enable register<br>(TMRx_IDEN) ..... | 300 |
| 14.3.5.3 TMR10, TMR11, TMR13 and TMR14 interrupt status register<br>(TMRxISTS) .....      | 300 |
| 14.3.5.4 TMR10, TMR11, TMR13 and TMR14 software event register<br>(TMRx_SWEVT).....       | 300 |
| 14.3.5.5 TMR10, TMR11, TMR13 and TMR14 channel mode register 1<br>(TMRx_CM1) .....        | 301 |
| 14.3.5.6 TMR10, TMR11, TMR13 and TMR14 channel control register<br>(TMRx_CCTRL) .....     | 302 |
| 14.3.5.7 TMR10, TMR11, TMR13 and TMR14 counter value (TMRx_CVAL)                          | 303 |
| 14.3.5.8 TMR10, TMR11, TMR13 and TMR14 division value (TMRx_DIV)                          | 303 |
| 14.3.5.9 TMR10, TMR11, TMR13 and TMR14 period register (TMRx_PR)                          | 303 |
| 14.3.5.10 TMR10, TMR11, TMR13 and TMR14 channel 1 data register<br>(TMRx_C1DT) .....      | 303 |
| 14.4 Advanced-control timers (TMR1, TMR8 and TMR20) .....                                 | 304 |
| 14.4.1 TMR1, TMR8 and TMR20 introduction .....                                            | 304 |
| 14.4.2 TMR1, TMR8 and TMR20 main features .....                                           | 304 |
| 14.4.3 TMR1, TMR8 and TMR20 functional overview .....                                     | 304 |
| 14.4.3.1 Counting clock.....                                                              | 304 |
| 14.4.3.2 Counting mode .....                                                              | 308 |
| 14.4.3.3 TMR input function.....                                                          | 312 |
| 14.4.3.4 TMR output function.....                                                         | 314 |
| 14.4.3.5 TMR brake function .....                                                         | 318 |
| 14.4.3.6 TMR synchronization.....                                                         | 319 |
| 14.4.3.7 Debug mode .....                                                                 | 320 |
| 14.4.4 TMR1, TMR8 and TMR20 registers.....                                                | 321 |
| 14.4.4.1 TMR1, TMR8 and TMR20 control register 1 (TMRx_CTRL1) .....                       | 321 |
| 14.4.4.2 TMR1, TMR8 and TMR20 control register 2 (TMRx_CTRL2) .....                       | 322 |
| 14.4.4.3 TMR1, TMR8 and TMR20 slave timer control register<br>(TMRx_STCTRL) .....         | 323 |
| 14.4.4.4 TMR1, TMR8 and TMR20 DMA/interrupt enable register<br>(TMRx_IDEN) .....          | 324 |
| 14.4.4.5 TMR1, TMR8 and TMR20 interrupt status register (TMRxISTS)                        | 325 |
| 14.4.4.6 TMR1, TMR8 and TMR20 software event register (TMRx_SWEVT)                        | 326 |

|           |                                                                   |            |
|-----------|-------------------------------------------------------------------|------------|
| 14.4.4.7  | TMR1, TMR8 and TMR20 channel mode register 1 (TMRx_CM1)           | 326        |
| 14.4.4.8  | TMR1, TMR8 and TMR20 channel mode register 2 (TMRx_CM2)           | 328        |
| 14.4.4.9  | TMR1, TMR8 and TMR20 channel control register (TMRx_CCTRL)        | 329        |
| 14.4.4.10 | TMR1, TMR8 and TMR20 counter value (TMRx_CVAL) .....              | 331        |
| 14.4.4.11 | TMR1, TMR8 and TMR20 division value (TMRx_DIV) .....              | 331        |
| 14.4.4.12 | TMR1, TMR8 and TMR20 period register (TMRx_PR).....               | 331        |
| 14.4.4.13 | TMR1, TMR8 and TMR20 repetition period register (TMRx_RPR)        | 331        |
| 14.4.4.14 | TMR1, TMR8 and TMR20 channel 1 data register (TMRx_C1DT)          | 331        |
| 14.4.4.15 | TMR1, TMR8 and TMR20 channel 2 data register (TMRx_C2DT)          | 332        |
| 14.4.4.16 | TMR1, TMR8 and TMR20 channel 3 data register (TMRx_C3DT)          | 332        |
| 14.4.4.17 | TMR1, TMR8 and TMR20 channel 4 data register (TMRx_C4DT)          | 332        |
| 14.4.4.18 | TMR1, TMR8 and TMR20 brake register (TMRx_BRK).....               | 332        |
| 14.4.4.19 | TMR1, TMR8 and TMR20 DMA control register<br>(TMRx_DMACTRL) ..... | 333        |
| 14.4.4.20 | TMR1, TMR8 and TMR20 DMA data register (TMRx_DMADT)               | 334        |
| 14.4.4.21 | TMR1, TMR8 and TMR20 channel mode register 3 (TMRx_CM3)           | 334        |
| 14.4.4.22 | TMR1, TMR8 and TMR20 channel 5 data register (TMRx_C5DT)          | 334        |
| <b>15</b> | <b>Window watchdog timer (WWDT) .....</b>                         | <b>335</b> |
| 15.1      | WWDT introduction .....                                           | 335        |
| 15.2      | WWDT main features .....                                          | 335        |
| 15.3      | WWDT functional overview .....                                    | 335        |
| 15.4      | Debug mode .....                                                  | 336        |
| 15.5      | WWDT registers .....                                              | 336        |
| 15.5.1    | Control register (WWDT_CTRL) .....                                | 336        |
| 15.5.2    | Configuration register (WWDT_CFG) .....                           | 336        |
| 15.5.3    | Status register (WWDT_STS) .....                                  | 337        |
| <b>16</b> | <b>Watchdog timer (WDT) .....</b>                                 | <b>338</b> |
| 16.1      | WDT introduction .....                                            | 338        |
| 16.2      | WDT main features .....                                           | 338        |
| 16.3      | WDT functional overview .....                                     | 338        |
| 16.4      | Debug mode .....                                                  | 339        |
| 16.5      | WDT registers .....                                               | 339        |
| 16.5.1    | Command register (WDT_CMD) .....                                  | 340        |
| 16.5.2    | Divider register (WDT_DIV).....                                   | 340        |

|                                                                |            |
|----------------------------------------------------------------|------------|
| 16.5.3 Reload register (WDT_RLD).....                          | 340        |
| 16.5.4 Status register (WDT_STS).....                          | 340        |
| 16.5.5 Window register (WDT_WIN).....                          | 340        |
| <b>17 Enhanced real-time clock (ERTC) .....</b>                | <b>341</b> |
| 17.1 ERTC introduction.....                                    | 341        |
| 17.2 ERTC main features.....                                   | 341        |
| 17.3 ERTC function overview .....                              | 342        |
| 17.3.1 ERTC clock.....                                         | 342        |
| 17.3.2 ERTC initialization.....                                | 342        |
| 17.3.3 Periodic automatic wakeup .....                         | 344        |
| 17.3.4 ERTC calibration .....                                  | 345        |
| 17.3.5 Reference clock detection.....                          | 346        |
| 17.3.6 Time stamp function .....                               | 346        |
| 17.3.7 Tamper detection .....                                  | 346        |
| 17.3.8 Multiplexed function output .....                       | 347        |
| 17.3.9 ERTC wakeup .....                                       | 347        |
| 17.4 ERTC registers .....                                      | 348        |
| 17.4.1 ERTC time register (ERTC_TIME) .....                    | 349        |
| 17.4.2 ERTC date register (ERTC_DATE) .....                    | 349        |
| 17.4.3 ERTC control register (ERTC_CTRL).....                  | 349        |
| 17.4.4 ERTC initialization and status register (ERTC_STS)..... | 351        |
| 17.4.5 ERTC divider register (ERTC_DIV) .....                  | 352        |
| 17.4.6 ERTC wakeup timer register (ERTC_WAT) .....             | 352        |
| 17.4.7 ERTC coarse calibration register (ERTC_CCAL) .....      | 352        |
| 17.4.8 ERTC alarm clock A register (ERTC_ALA) .....            | 353        |
| 17.4.9 ERTC alarm clock B register (ERTC_ALB) .....            | 353        |
| 17.4.10 ERTC write protection register (ERTC_WP) .....         | 354        |
| 17.4.11 ERTC subsecond register (ERTC_SBS) .....               | 354        |
| 17.4.12 ERTC time adjustment register (ERTC_TADJ) .....        | 354        |
| 17.4.13 ERTC time stamp time register (ERTC_TSTM) .....        | 354        |
| 17.4.14 ERTC time stamp date register (ERTC_TSDT) .....        | 355        |
| 17.4.15 ERTC time stamp subsecond register (ERTC_TSSBS).....   | 355        |
| 17.4.16 ERTC smooth calibration register (ERTC_SCAL) .....     | 355        |
| 17.4.17 ERTC tamper configuration register (ERTC_TAMP) .....   | 355        |

|                                                                     |            |
|---------------------------------------------------------------------|------------|
| 17.4.18 ERTC alarm clock A subsecond register (ERTC_ALASBS) .....   | 357        |
| 17.4.19 ERTC alarm clock B subsecond register (ERTC_ALBSBS) .....   | 357        |
| 17.4.20 ERTC battery powered domain data register (ERTC_BPRx) ..... | 357        |
| <b>18 Analog-to-digital converter (ADC).....</b>                    | <b>358</b> |
| 18.1 ADC introduction .....                                         | 358        |
| 18.2 ADC main features.....                                         | 358        |
| 18.3 ADC structure.....                                             | 358        |
| 18.4 ADC functional overview.....                                   | 359        |
| 18.4.1 Channel management.....                                      | 359        |
| 18.4.1.1 Internal temperature sensor.....                           | 360        |
| 18.4.1.2 Internal reference voltage.....                            | 360        |
| 18.4.1.3 Battery voltage .....                                      | 360        |
| 18.4.2 ADC operation process.....                                   | 360        |
| 18.4.2.1 Power-on and calibration .....                             | 361        |
| 18.4.2.2 Trigger.....                                               | 362        |
| 18.4.2.3 Sampling and conversion sequence.....                      | 363        |
| 18.4.3 Conversion sequence management .....                         | 363        |
| 18.4.3.1 Sequence mode .....                                        | 363        |
| 18.4.3.2 Automatic preempted group conversion mode .....            | 364        |
| 18.4.3.3 Repetition mode.....                                       | 364        |
| 18.4.3.4 Partition mode .....                                       | 365        |
| 18.4.4 End of conversion .....                                      | 365        |
| 18.4.5 Oversampling.....                                            | 366        |
| 18.4.5.1 Oversampling of ordinary group of channels.....            | 367        |
| 18.4.5.2 Oversampling of preempted group of channels .....          | 368        |
| 18.4.6 Data management .....                                        | 368        |
| 18.4.6.1 Data alignment .....                                       | 368        |
| 18.4.6.2 Data read .....                                            | 369        |
| 18.4.7 Voltage monitoring .....                                     | 369        |
| 18.4.7.1 Status flag and interrupts .....                           | 370        |
| 18.5 Master/Slave mode .....                                        | 370        |
| 18.5.1 Data management .....                                        | 371        |
| 18.5.2 Simultaneous mode .....                                      | 371        |
| 18.5.3 Alternate preempted trigger mode .....                       | 372        |
| 18.5.4 Regular shift mode .....                                     | 373        |

|                                                                                   |            |
|-----------------------------------------------------------------------------------|------------|
| 18.6 ADC registers .....                                                          | 374        |
| 18.6.1 ADC status register (ADC_STS) .....                                        | 376        |
| 18.6.2 ADC control register 1 (ADC_CTRL1) .....                                   | 377        |
| 18.6.3 ADC control register 2 (ADC_CTRL2) .....                                   | 378        |
| 18.6.4 ADC sampling time register 1 (ADC_SPT1) .....                              | 380        |
| 18.6.5 ADC sampling time register 2 (ADC_SPT2) .....                              | 382        |
| 18.6.6 ADC preempted channel data offset register x<br>(ADC_PCDTOx) (x=1..4)..... | 384        |
| 18.6.7 ADC voltage monitor high threshold register (ADC_VVHB) .....               | 384        |
| 18.6.8 ADC voltage monitor low threshold register (ADC_VVLB).....                 | 384        |
| 18.6.9 ADC ordinary sequence register 1 (ADC_OSQ1) .....                          | 384        |
| 18.6.10 ADC ordinary sequence register 2 (ADC_OSQ2) .....                         | 384        |
| 18.6.11 ADC ordinary sequence register 3 (ADC_OSQ3) .....                         | 385        |
| 18.6.12 ADC preempted sequence register (ADC_PSQ).....                            | 385        |
| 18.6.13 ADC preempted data register x (ADC_PDTx) (x=1..4) .....                   | 385        |
| 18.6.14 ADC ordinary data register (ADC_ODT) .....                                | 386        |
| 18.6.15 ADC oversampling register (ADC_OVSP) .....                                | 386        |
| 18.6.16 ADC calibration value register (ADC_CALVAL) .....                         | 387        |
| 18.6.17 ADC common status register (ADC_CSTS).....                                | 387        |
| 18.6.18 ADC common control register (ADC_CCTRL) .....                             | 388        |
| 18.6.19 ADC common data register (ADC_CODT).....                                  | 391        |
| <b>19 Digital-to-analog converter (DAC) .....</b>                                 | <b>392</b> |
| 19.1 DAC introduction .....                                                       | 392        |
| 19.2 DAC main features.....                                                       | 392        |
| 19.3 Design tips .....                                                            | 392        |
| 19.4 Functional overview .....                                                    | 393        |
| 19.4.1 Trigger events.....                                                        | 393        |
| 19.4.2 Noise/Triangular-wave generation .....                                     | 393        |
| 19.4.3 DAC data alignment .....                                                   | 394        |
| 19.5 DAC registers .....                                                          | 395        |
| 19.5.1 DAC control register (DAC_CTRL).....                                       | 395        |
| 19.5.2 DAC software trigger register (DAC_SWTRG) .....                            | 398        |
| 19.5.3 DAC1 12-bit right-aligned data holding register (DAC_D1DTH12R)             | 398        |
| 19.5.4 DAC1 12-bit left-aligned data holding register (DAC_D1DTH12L)              | .398       |

|                                                                                    |     |
|------------------------------------------------------------------------------------|-----|
| 19.5.5 DAC1 8-bit right-aligned data holding register (DAC_ D1DTH8R) ..            | 398 |
| 19.5.6 DAC2 12-bit right-aligned data holding register (DAC_ D2DTH12R)             | 398 |
| 19.5.7 DAC2 12-bit left-aligned data holding register (DAC_ D2DTH12L) .            | 398 |
| 19.5.8 DAC2 8-bit right-aligned data holding register (DAC_ D2DTH8R) ..            | 399 |
| 19.5.9 Dual DAC 12-bit right-aligned data holding register<br>(DAC_ DDTH12R) ..... | 399 |
| 19.5.10 Dual DAC 12-bit left-aligned data holding register<br>(DAC_ DDTH12L).....  | 399 |
| 19.5.11 Dual DAC 8-bit right-aligned data holding register<br>(DAC_ DDTH8R) .....  | 399 |
| 19.5.12 DAC1 data output register (DAC_ D1ODT) .....                               | 399 |
| 19.5.13 DAC2 data output register (DAC_ D2ODT) .....                               | 399 |
| 19.5.14 DAC status register (DAC_STS) .....                                        | 399 |

## 20 CAN 400

|                                                          |     |
|----------------------------------------------------------|-----|
| 20.1 CAN introduction .....                              | 400 |
| 20.2 CAN main features.....                              | 400 |
| 20.3 Baud rate .....                                     | 400 |
| 20.4 Interrupt management .....                          | 403 |
| 20.5 Design tips .....                                   | 404 |
| 20.6 Functional overview .....                           | 404 |
| 20.6.1 General description .....                         | 404 |
| 20.6.2 Operating modes .....                             | 405 |
| 20.6.3 Test modes .....                                  | 405 |
| 20.6.4 Message filtering .....                           | 406 |
| 20.6.5 Message transmission .....                        | 407 |
| 20.6.6 Message reception .....                           | 409 |
| 20.6.7 Error management.....                             | 409 |
| 20.7 CAN registers .....                                 | 410 |
| 20.7.1 CAN control and status registers .....            | 411 |
| 20.7.1.1 CAN master control register (CAN_MCTRL) .....   | 411 |
| 20.7.1.2 CAN master status register (CAN_MSTS).....      | 412 |
| 20.7.1.3 CAN transmit status register (CAN_TSTS) .....   | 413 |
| 20.7.1.4 CAN receive FIFO 0 register (CAN_RF0) .....     | 416 |
| 20.7.1.5 CAN receive FIFO 1 register (CAN_RF1) .....     | 416 |
| 20.7.1.6 CAN interrupt enable register (CAN_INTEN) ..... | 417 |

|                                                                                                |            |
|------------------------------------------------------------------------------------------------|------------|
| 20.7.1.7 CAN error status register (CAN_ESTS) .....                                            | 418        |
| 20.7.1.8 CAN bit timing register (CAN_BTMG) .....                                              | 419        |
| 20.7.2 CAN mailbox registers .....                                                             | 419        |
| 20.7.2.1 Transmit mailbox identifier register (CAN_TMIx) (x=0..2) .....                        | 420        |
| 20.7.2.2 Transmit mailbox data length and time stamp register<br>(CAN_TMCx) (x=0..2).....      | 420        |
| 20.7.2.3 Transmit mailbox data low register (CAN_TMDTLx) (x=0..2) .....                        | 421        |
| 20.7.2.4 Transmit mailbox data high register (CAN_TMDTHx) (x=0..2) ...                         | 421        |
| 20.7.2.5 Receive FIFO mailbox identifier register (CAN_RFIdx) (x=0..1) ..                      | 421        |
| 20.7.2.6 Receive FIFO mailbox data length and time stamp register<br>(CAN_RFCx) (x=0..1) ..... | 421        |
| 20.7.2.7 Receive FIFO mailbox data low register (CAN_RFDTLx) (x=0..1)                          | 422        |
| 20.7.2.8 Receive FIFO mailbox data high register (CAN_RFDTThx) (x=0..1)                        | 422        |
| 20.7.3 CAN filter registers.....                                                               | 422        |
| 20.7.3.1 CAN filter control register (CAN_FCTRL) .....                                         | 422        |
| 20.7.3.2 CAN filter mode configuration register (CAN_FMCFG) .....                              | 422        |
| 20.7.3.3 CAN filter bit width configuration register (CAN_FBWCFG).....                         | 422        |
| 20.7.3.4 CAN filter FIFO association register (CAN_FRF) .....                                  | 423        |
| 20.7.3.5 CAN filter activation control register (CAN_FACFG).....                               | 423        |
| 20.7.3.6 CAN filter bank i filter bit register (CAN_FiFBx) (i=0..13; x=1..2)                   | 423        |
| <b>21 Universal serial bus full-speed device interface (OTGFS).....</b>                        | <b>424</b> |
| 21.1 USBFS structure.....                                                                      | 424        |
| 21.2 OTGFS functional description .....                                                        | 424        |
| 21.3 OTGFS clock and pin configuration .....                                                   | 425        |
| 21.3.1 OTGFS clock configuration .....                                                         | 425        |
| 21.3.2 OTGFS pin configuration .....                                                           | 425        |
| 21.4 OTGFS interrupts .....                                                                    | 426        |
| 21.5 OTGFS functional description .....                                                        | 426        |
| 21.5.1 OTGFS initialization .....                                                              | 426        |
| 21.5.2 OTGFS FIFO configuration .....                                                          | 427        |
| 21.5.2.1 Device mode .....                                                                     | 427        |
| 21.5.2.2 Host mode.....                                                                        | 428        |
| 21.5.2.3 Refresh controller transmit FIFO .....                                                | 429        |
| 21.5.3 OTGFS host mode.....                                                                    | 429        |
| 21.5.3.1 Host initialization .....                                                             | 429        |
| 21.5.3.2 OTGFS channel initialization.....                                                     | 430        |

|                                                                           |     |
|---------------------------------------------------------------------------|-----|
| 21.5.3.3 Halting a channel.....                                           | 430 |
| 21.5.3.4 Queue depth.....                                                 | 431 |
| 21.5.3.5 Special cases .....                                              | 432 |
| 21.5.3.6 Host HFIR feature .....                                          | 432 |
| 21.5.3.7 Initialize bulk and control IN transfers.....                    | 434 |
| 21.5.3.8 Initialize bulk and control OUT/SETUP transfers.....             | 436 |
| 21.5.3.9 Initialize interrupt IN transfers.....                           | 438 |
| 21.5.3.10 Initialize interrupt OUT transfers .....                        | 440 |
| 21.5.3.11 Initialize synchronous IN transfers.....                        | 442 |
| 21.5.3.12 Initialize synchronous OUT transfers .....                      | 443 |
| 21.5.4 OTGFS device mode .....                                            | 445 |
| 21.5.4.1 Device initialization .....                                      | 445 |
| 21.5.4.2 Endpoint initialization on USB reset.....                        | 445 |
| 21.5.4.3 Endpoint initialization on enumeration completion.....           | 446 |
| 21.5.4.4 Endpoint initialization on SetAddress command.....               | 446 |
| 21.5.4.5 Endpoint initialization on SetConfiguration/SetInterface command | 446 |
| 21.5.4.6 Endpoint activation .....                                        | 446 |
| 21.5.4.7 USB endpoint deactivation.....                                   | 447 |
| 21.5.4.8 Control write transfers (SETUP/Data OUT/Status IN) .....         | 447 |
| 21.5.4.9 Control read transfers (SETUP/Data IN/Status OUT).....           | 447 |
| 21.5.4.10 Control transfers (SETUP/Status IN).....                        | 448 |
| 21.5.4.11 Read FIFO packets .....                                         | 448 |
| 21.5.4.12 OUT data transfers .....                                        | 450 |
| 21.5.4.13 IN data transfers .....                                         | 451 |
| 21.5.4.14 Non-periodic (bulk and control) IN data transfers.....          | 452 |
| 21.5.4.15 Non-synchronous OUT data transfers .....                        | 453 |
| 21.5.4.16 Synchronous OUT data transfers.....                             | 455 |
| 21.5.4.17 Enable synchronous endpoints.....                               | 456 |
| 21.5.4.18 Incomplete synchronous OUT data transfers .....                 | 458 |
| 21.5.4.19 Incomplete synchronous IN data transfers.....                   | 459 |
| 21.5.4.20 Periodic IN (interrupt and synchronous) data transfers .....    | 459 |
| 21.6 OTGFS control and status registers.....                              | 461 |
| 21.6.1 CSR register map.....                                              | 461 |
| 21.6.2 OTGFS register address map .....                                   | 462 |
| 21.6.3 OTGFS global registers .....                                       | 466 |
| 21.6.3.1 OTGFS status and control register (OTGFS_GOTGCTL) .....          | 466 |
| 21.6.3.2 OTGFS interrupt status control register (OTGFS_GOTGINT) ....     | 466 |
| 21.6.3.3 OTGFS AHB configuration register (OTGFS_GAHBCFG).....            | 466 |

|                                                                                                                                                   |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 21.6.3.4 OTGFS USB configuration register (OTGFS_GUSBCFG).....                                                                                    | 467 |
| 21.6.3.5 OTGFS reset register (OTGFS_GRSTCTL).....                                                                                                | 468 |
| 21.6.3.6 OTGFS interrupt register (OTGFS_GINTSTS).....                                                                                            | 470 |
| 21.6.3.7 OTGFS interrupt mask register (OTGFS_GINTMSK) .....                                                                                      | 473 |
| 21.6.3.8 OTGFS receive status debug read/OTG status read and POP registers (OTGFS_GRXSTSR / OTGFS_GRXSTSP).....                                   | 474 |
| 21.6.3.9 OTGFS receive FIFO size register (OTGFS_GRXFSIZ) .....                                                                                   | 475 |
| 21.6.3.10 OTGFS non-periodic Tx FIFO size (OTGFS_GNPTXFSIZ)/Endpoint 0 Tx FIFO size registers (OTGFS_DIEPTXF0).....                               | 475 |
| 21.6.3.11 OTGFS non-periodic Tx FIFO size/request queue status register (OTGFS_GNPTXSTS) .....                                                    | 476 |
| 21.6.3.12 OTGFS general controller configuration register (OTGFS_GCCFG) .....                                                                     | 476 |
| 21.6.3.13 OTGFS controller ID register (OTGFS_GUID).....                                                                                          | 477 |
| 21.6.3.14 OTGFS host periodic Tx FIFO size register (OTGFS_HPTXFSIZ) .....                                                                        | 477 |
| 21.6.3.15 OTGFS device IN endpoint Tx FIFO size register (OTGFS_DIEPTXF <sub>n</sub> ) ( $x=1\dots7$ , where n is the FIFO number) .....          | 477 |
| 21.6.4 Host-mode registers .....                                                                                                                  | 477 |
| 21.6.4.1 OTGFS host mode configuration register (OTGFS_HCFG).....                                                                                 | 477 |
| 21.6.4.2 OTGFS host frame interval register (OTGFS_HFIR).....                                                                                     | 478 |
| 21.6.4.3 OTGFS host frame number/frame time remaining register (OTGFS_HFNUM) .....                                                                | 478 |
| 21.6.4.4 OTGFS host periodic Tx FIFO/request queue register (OTGFS_HPTXSTS).....                                                                  | 479 |
| 21.6.4.5 OTGFS host all channels interrupt register (OTGFS_HAINT) ...                                                                             | 479 |
| 21.6.4.6 OTGFS host all channels interrupt mask register (OTGFS_HAINTMSK) .....                                                                   | 479 |
| 21.6.4.7 OTGFS host port control and status register (OTGFS_HPRT) ...                                                                             | 480 |
| 21.6.4.8 OTGFS host channel <sub>x</sub> characteristics register (OTGFS_HCCHAR <sub>x</sub> ) ( $x = 0\dots15$ , where x= channel number).....   | 481 |
| 21.6.4.9 OTGFS host channel <sub>x</sub> interrupt register (OTGFS_HCINT <sub>x</sub> ) ( $x = 0\dots15$ , where x= channel number).....          | 482 |
| 21.6.4.10 OTGFS host channel <sub>x</sub> interrupt mask register (OTGFS_HCINTMSK <sub>x</sub> ) ( $x = 0\dots15$ , where x= channel number)..... | 483 |
| 21.6.4.11 OTGFS host channel <sub>x</sub> transfer size register (OTGFS_HCTSIZ <sub>x</sub> ) ( $x = 0\dots15$ , where x= channel number).....    | 483 |
| 21.6.5 Device-mode registers .....                                                                                                                | 484 |
| 21.6.5.1 OTGFS device configure register (OTGFS_DCFG).....                                                                                        | 484 |
| 21.6.5.2 OTGFS device control register (OTGFS_DCTL) .....                                                                                         | 484 |

|                                                                                                                                |            |
|--------------------------------------------------------------------------------------------------------------------------------|------------|
| 21.6.5.3 OTGFS device status register (OTGFS_DSTS) .....                                                                       | 486        |
| 21.6.5.4 OTGFS device OTGFSIN endpoint common interrupt mask register (OTGFS_DIEPMSK) .....                                    | 486        |
| 21.6.5.5 OTGFS device OUT endpoint common interrupt mask register (OTGFS_DOEPMSK).....                                         | 487        |
| 21.6.5.6 OTGFS device all endpoints interrupt mask register (OTGFS_DAINT).....                                                 | 488        |
| 21.6.5.7 OTGFS all endpoints interrupt mask register (OTGFS_DAINTMSK)                                                          | 488        |
| 21.6.5.8 OTGFS device IN endpoint FIFO empty interrupt mask register (OTGFS_DIEPEMPMSK) .....                                  | 488        |
| 21.6.5.9 OTGFS device control IN endpoint 0 control register (OTGFS_DIEPCTL0) .....                                            | 488        |
| 21.6.5.10 OTGFS device IN endpoint-x control register (OTGFS_DIEPCTLx) (x=x=1...7, where x is endpoint number) .....           | 490        |
| 21.6.5.11 OTGFS device control OUT endpoint 0 control register (OTGFS_DOEPCTL0).....                                           | 492        |
| 21.6.5.12 OTGFS device control OUT endpoint-x control register (OTGFS_DOEPCTLx) (x= x=1...7, where x if endpoint number) ..... | 493        |
| 21.6.5.13 OTGFS device IN endpoint-x interrupt register (OTGFS_DIEPINTx) (x=0...7, where x if endpoint number) .....           | 495        |
| 21.6.5.14 OTGFS device OUT endpoint-x interrupt register (OTGFS_DOEPINTx) (x=0...7, where x if endpoint number).....           | 495        |
| 21.6.5.15 OTGFS device IN endpoint 0 transfer size register (OTGFS_DIEPTSIZ0) .....                                            | 496        |
| 21.6.5.16 OTGFS device OUT endpoint 0 transfer size register (OTGFS_DOEPTSIZ0).....                                            | 496        |
| 21.6.5.17 OTGFS device IN endpoint-x transfer size register (OTGFS_DIEPTSIZx) (x=1...7, where x is endpoint number).....       | 497        |
| 21.6.5.18 OTGFS device IN endpoint transmit FIFO status register (OTGFS_DTXFSTSx) (x=1...7, where x is endpoint number).....   | 497        |
| 21.6.5.19 OTGFS device OUT endpoint-x transfer size register (OTGFS_DOEPTSIZx) (x=1...7, where x is endpoint number) .....     | 498        |
| 21.6.6 Power and clock control registers .....                                                                                 | 498        |
| 21.6.6.1 OTGFS power and clock gating control register (OTGFS_PCGCCTL) .....                                                   | 498        |
| <b>22 HICK auto clock calibration (ACC) .....</b>                                                                              | <b>499</b> |
| 22.1 ACC introduction .....                                                                                                    | 499        |
| 22.2 Main features .....                                                                                                       | 499        |
| 22.3 Interrupt requests .....                                                                                                  | 499        |

|                                                           |            |
|-----------------------------------------------------------|------------|
| 22.4 Functional description .....                         | 499        |
| 22.5 Principle.....                                       | 500        |
| 22.6 Register description .....                           | 501        |
| 22.6.1 ACC register map.....                              | 502        |
| 22.6.2 Status register (ACC_STS) .....                    | 502        |
| 22.6.3 Control register 1 (ACC_CTRL1) .....               | 502        |
| 22.6.4 Control register 2 (ACC_CTRL2) .....               | 503        |
| 22.6.5 Compare value 1 (ACC_C1) .....                     | 503        |
| 22.6.6 Compare value 2 (ACC_C2) .....                     | 504        |
| 22.6.7 Compare value 3 (ACC_C3) .....                     | 504        |
| <b>23 Infrared timer (IRTMR) .....</b>                    | <b>505</b> |
| <b>24 External memory controller (XMC) .....</b>          | <b>506</b> |
| 24.1 XMC introduction .....                               | 506        |
| 24.2 XMC main features .....                              | 506        |
| 24.3 XMC architecture .....                               | 508        |
| 24.3.1 Block diagram .....                                | 508        |
| 24.3.2 Address mapping .....                              | 510        |
| 24.4 NOR/PSRAM .....                                      | 512        |
| 24.4.1 Operating mode .....                               | 512        |
| 24.4.2 Access mode .....                                  | 513        |
| 24.4.2.1 Read/write operation with the same timings ..... | 514        |
| 24.4.2.2 Read/write operation with different timings..... | 517        |
| 24.4.2.3 Multiplexed mode.....                            | 525        |
| 24.4.2.4 Synchronous mode.....                            | 527        |
| 24.5 NAND .....                                           | 529        |
| 24.5.1 Operating mode .....                               | 529        |
| 24.5.2 Access timings .....                               | 530        |
| 24.5.3 ECC computation .....                              | 531        |
| 24.6 PC card.....                                         | 531        |
| 24.6.1 Operating mode .....                               | 532        |
| 24.6.2 Access timings .....                               | 532        |
| 24.7 SDRAM card.....                                      | 533        |
| 24.7.1 SDRAM access management .....                      | 533        |

|                                                                                          |            |
|------------------------------------------------------------------------------------------|------------|
| 24.7.2 Self-refresh mode and Power-down mode .....                                       | 536        |
| <b>24.8 XMC registers.....</b>                                                           | <b>536</b> |
| 24.8.1 NOR Flash and PSRAM control registers .....                                       | 537        |
| 24.8.1.1 SRAM/NOR Flash chip select control register 1<br>(XMC_BK1CTRL1) .....           | 537        |
| 24.8.1.2 SRAM/NOR Flash chip select control register x (x=2, 3, 4) .....                 | 538        |
| 24.8.1.3 SRAM/NOR Flash chip select timing register x (XMC_BK1TMGx)<br>(x=1,2,3,4) ..... | 540        |
| 24.8.1.4 SRAM/NOR Flash write timing register x (XMC_BK1TMGWRx),<br>x=1,2,3,4 .....      | 540        |
| 24.8.1.5 SRAM/NOR Flash extra timing register x (XMC_EXTx)<br>(x=1,2,3,4) .....          | 541        |
| 24.8.2 NAND Flash control registers .....                                                | 542        |
| 24.8.2.1 NAND Flash control register x (XMC_BKxCTRL) (x=2,3) .....                       | 542        |
| 24.8.2.2 Interrupt enable and FIFO status register x (XMC_BKxIS) (x=2,3)                 | 542        |
| 24.8.2.3 Regular memory timing register x (XMC_BKxTMGRG) (x=2,3) ..                      | 543        |
| 24.8.2.4 Special memory timing register x (XMC_BKxTMGSP) (x=2,3) ..                      | 543        |
| 24.8.2.5 ECC value register x (XMC_BKxCC) (x=2,3).....                                   | 544        |
| 24.8.3 PC card controller registers .....                                                | 544        |
| 24.8.3.1 PC card control register (XMC_BK4CTRL) .....                                    | 544        |
| 24.8.3.2 Interrupt enable and FIFO status register 4 (XMC_BK4IS).....                    | 544        |
| 24.8.3.3 Common memory timing register 4 (XMC_BK4TMGCM) .....                            | 545        |
| 24.8.3.4 Attribute memory timing register 4 (XMC_BK4TMGAT) .....                         | 545        |
| 24.8.3.5 IO space timing register 4 (XMC_BK4TMGIO) .....                                 | 546        |
| 24.8.4 SDRAM controller registers.....                                                   | 546        |
| 24.8.4.1 SDRAM control register 1, 2 (SDRAM_CTRL1,SDRAM_CTRL2) ..                        | 546        |
| 24.8.4.2 SDRAM timing register 1, 2 (SDRAM_TM1,SDRAM_TM2).....                           | 547        |
| 24.8.4.3 SDRAM command register (SDRAM_CMD).....                                         | 549        |
| 24.8.4.4 SDRAM refresh timer register (SDRAM_RCNT) .....                                 | 549        |
| 24.8.4.5 SDRAM status register (SDRAM_STS).....                                          | 550        |
| <b>25 SDIO interface.....</b>                                                            | <b>551</b> |
| 25.1 SDIO introduction .....                                                             | 551        |
| 25.2 SDIO main features.....                                                             | 551        |
| 25.3 Functional description .....                                                        | 553        |
| 25.3.1 Card functional description .....                                                 | 553        |
| 25.3.1.1 Card identification mode.....                                                   | 553        |
| 25.3.1.2 Data transfer mode .....                                                        | 554        |

|                                                                  |            |
|------------------------------------------------------------------|------------|
| 25.3.1.3 Erase .....                                             | 555        |
| 25.3.1.4 Protection management .....                             | 555        |
| 25.3.2 Commands and responses .....                              | 558        |
| 25.3.2.1 Commands .....                                          | 558        |
| 25.3.2.2 Response formats .....                                  | 562        |
| 25.3.3 SDIO functional description .....                         | 564        |
| 25.3.3.1 SDIO adapter .....                                      | 565        |
| 25.3.3.2 Data BUF .....                                          | 569        |
| 25.3.3.3 SDIO AHB interface .....                                | 569        |
| 25.3.3.4 Hardware flow control.....                              | 570        |
| 25.3.4 SDIO I/O card-specific operations .....                   | 570        |
| 25.4 SDIO registers .....                                        | 571        |
| 25.4.1 SDIO power control register (SDIO_PWRCTRL) .....          | 571        |
| 25.4.2 SDIO clock control register (SDIO_CLKCTRL) .....          | 572        |
| 25.4.3 SDIO argument register (SDIO_ARG) .....                   | 573        |
| 25.4.4 SDIO command register (SDIO_CMD) .....                    | 573        |
| 25.4.5 SDIO command response register (SDIO_RSPCMD) .....        | 574        |
| 25.4.6 SDIO response 1..4 register (SDIO_RSPx) .....             | 574        |
| 25.4.7 SDIO data timer register (SDIO_DTTMR).....                | 574        |
| 25.4.8 SDIO data length register (SDIO_DTLEN).....               | 574        |
| 25.4.9 SDIO data control register (SDIO_DTCTRL).....             | 575        |
| 25.4.10 SDIO data counter register (SDIO_DTCNTR) .....           | 576        |
| 25.4.11 SDIO status register (SDIO_STS) .....                    | 576        |
| 25.4.12 SDIO clear interrupt register (SDIO_INTCLR).....         | 577        |
| 25.4.13 SDIO interrupt mask register (SDIO_INTEN) .....          | 577        |
| 25.4.14 SDIOBUF counter register (SDIO_BUFCNTR) .....            | 579        |
| 25.4.15 SDIO data BUF register (SDIO_BUF) .....                  | 579        |
| <b>26 Ethernet media access control (EMAC).....</b>              | <b>580</b> |
| 26.1 EMAC introduction .....                                     | 580        |
| 26.1.1 EMAC structure .....                                      | 580        |
| 26.1.2 EMAC main features.....                                   | 580        |
| 26.2 EMAC functional description .....                           | 581        |
| 26.2.1 EMAC communication interfaces .....                       | 581        |
| 26.2.2 EMAC frame communication .....                            | 586        |
| 26.2.3 Ethernet frame transmission and reception using DMA ..... | 594        |

|                                                                                           |            |
|-------------------------------------------------------------------------------------------|------------|
| 26.2.4 Enter and wake up EMAC power-down mode .....                                       | 608        |
| 26.2.5 IEEE1588 precision time protocol .....                                             | 609        |
| 26.2.6 EMAC interrupts .....                                                              | 613        |
| <b>26.3 EMAC registers .....</b>                                                          | <b>614</b> |
| 26.3.1 Ethernet MAC configuration register (EMAC_MACCTRL) .....                           | 616        |
| 26.3.2 Ethernet MAC frame filter register (EMAC_MACFRMF) .....                            | 618        |
| 26.3.3 Ethernet MAC Hash table high register (EMAC_MACHTH) .....                          | 620        |
| 26.3.4 Ethernet MAC Hash table low register (EMAC_MACHTL) .....                           | 620        |
| 26.3.5 Ethernet MAC MII address register (EMAC_MACMIIADDR) .....                          | 620        |
| 26.3.6 Ethernet MAC MII data register (EMAC_MACMIIDT) .....                               | 621        |
| 26.3.7 Ethernet MAC flow control register (EMAC_MACFCTRL) .....                           | 621        |
| 26.3.8 Ethernet MAC VLAN tag register (EMAC_MACVLT) .....                                 | 623        |
| 26.3.9 Ethernet MAC remote wakeup frame filter register<br>(EMAC_MACRWFF) .....           | 623        |
| 26.3.10 Ethernet MAC PMT control and status register<br>(EMAC_MACPMTCTRLSTS) .....        | 624        |
| 26.3.11 Ethernet MAC interrupt status register (EMAC_MACISTS) .....                       | 624        |
| 26.3.12 Ethernet MAC interrupt mask register (EMAC_MAIMR) .....                           | 625        |
| 26.3.13 Ethernet MAC address 0 high register (EMAC_MACA0H) .....                          | 625        |
| 26.3.14 Ethernet MAC address 0 low register (EMAC_MACA0L) .....                           | 626        |
| 26.3.15 Ethernet MAC address 1 high register (EMAC_MACA1H) .....                          | 626        |
| 26.3.16 Ethernet MAC address 1 low register (EMAC_MACA1L) .....                           | 626        |
| 26.3.17 Ethernet MAC address 2 high register (EMAC_MACA2H) .....                          | 627        |
| 26.3.18 Ethernet MAC address 2 low register (EMAC_MACA2L) .....                           | 627        |
| 26.3.19 Ethernet MAC address 3 high register (EMAC_MACA3H) .....                          | 627        |
| 26.3.20 Ethernet MAC address 3 low register (EMAC_MACA3L) .....                           | 628        |
| 26.3.21 Ethernet DMA bus mode register (EMAC_DMABM) .....                                 | 628        |
| 26.3.22 Ethernet DMA transmit poll demand register (EMAC_DMATPD) ..                       | 630        |
| 26.3.23 Ethernet DMA receive poll demand register (EMAC_DMARPD) ..                        | 630        |
| 26.3.24 Ethernet DMA receive descriptor list address register<br>(EMAC_DMARDLADDR) .....  | 630        |
| 26.3.25 Ethernet DMA transmit descriptor list address register<br>(EMAC_DMATDLADDR) ..... | 631        |
| 26.3.26 Ethernet DMA status register (EMAC_DMASTS) .....                                  | 631        |
| 26.3.27 Ethernet DMA operation mode register (EMAC_DMAOPM) .....                          | 634        |
| 26.3.28 Ethernet DMA interrupt enable register (EMAC_DMAIE) .....                         | 636        |

|                                                                                                                     |     |
|---------------------------------------------------------------------------------------------------------------------|-----|
| 26.3.29 Ethernet DMA missed frame and buffer overflow counter register<br>(EMAC_DMAMFBOCNT).....                    | 637 |
| 26.3.30 Ethernet DMA current transmit descriptor register<br>(EMAC_DMACTD) .....                                    | 638 |
| 26.3.31 Ethernet DMA current receive descriptor register<br>(EMAC_DMACRD) .....                                     | 638 |
| 26.3.32 Ethernet DMA current transmit buffer address register<br>(EMAC_DMACTBADDR) .....                            | 638 |
| 26.3.33 Ethernet DMA current receive buffer address register<br>(EMAC_DMACRBADDR).....                              | 638 |
| 26.3.34 Ethernet MMC control register (EMAC_MMCTRL) .....                                                           | 638 |
| 26.3.35 Ethernet MMC receive interrupt register (EMAC_MMCR) .....                                                   | 639 |
| 26.3.36 Ethernet MMC transmit interrupt register (EMAC_MMCTI).....                                                  | 639 |
| 26.3.37 Ethernet MMC receive interrupt register (EMAC_MMCRIM) .....                                                 | 640 |
| 26.3.38 Ethernet MMC transmit interrupt register (EMAC_MMCTIM) .....                                                | 640 |
| 26.3.39 Ethernet MMC transmitted good frame single collision counter register<br>(EMAC_MMCTFSCC) .....              | 640 |
| 26.3.40 Ethernet MMC transmitted good frame more than a single collision<br>counter register (EMAC_MMCTFMSCC) ..... | 641 |
| 26.3.41 Ethernet MMC transmitted good frames counter register<br>(EMAC_MMCTFCNT) .....                              | 641 |
| 26.3.42 Ethernet MMC received frames with CRC error counter register<br>(EMAC_MMCRFCECR).....                       | 641 |
| 26.3.43 Ethernet MMC received frames with alignment error counter register<br>(EMAC_MMCRFAECNT).....                | 641 |
| 26.3.44 Ethernet MMC received good unicast frames counter register<br>(EMAC_MMCRGUFCNT) .....                       | 641 |
| 26.3.45 Ethernet PTP time stamp control register (EMAC_PTPTSCTRL) .641                                              |     |
| 26.3.46 Ethernet PTP subsecond increment register (EMAC_PTPSSINC)643                                                |     |
| 26.3.47 Ethernet PTP time stamp high register (EMAC_PTPTSH).....643                                                 |     |
| 26.3.48 Ethernet PTP time stamp low register (EMAC_PTPTSL) .....                                                    | 644 |
| 26.3.49 Ethernet PTP time stamp high update register (EMAC_PTPTSHUD)644                                             |     |
| 26.3.50 Ethernet PTP time stamp low update register (EMAC_PTPTSLUD)644                                              |     |
| 26.3.51 Ethernet PTP time stamp addend register (EMAC_PTPTSAD) ....644                                              |     |
| 26.3.52 Ethernet PTP target time high register (EMAC_PTPTTH) .....                                                  | 645 |
| 26.3.53 Ethernet PTP target time low register (EMAC_PTPTTL) .....                                                   | 645 |

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| 26.3.54 Ethernet PTP time stamp status register (EMAC_PTPTSSR) ..... | 645 |
| 26.3.55 Ethernet PTP PPS register (EMAC_PTPPPSCR) .....              | 645 |

|                                                                     |            |
|---------------------------------------------------------------------|------------|
| <b>27 Digital Video parallel interface (DVP).....</b>               | <b>647</b> |
| 27.1 Introduction .....                                             | 647        |
| 27.2 Introduction .....                                             | 647        |
| 27.3 Data capture and synchronization .....                         | 648        |
| 27.3.1 Hardware synchronization mode.....                           | 648        |
| 27.3.2 Embedded data synchronization mode.....                      | 649        |
| 27.3.3 Data alignment.....                                          | 650        |
| 27.3.4 Single frame and continuous capture modes .....              | 651        |
| 27.4 DMA access interface and data output packing .....             | 652        |
| 27.4.1 DMA access interface.....                                    | 652        |
| 27.4.2 Data output packing .....                                    | 652        |
| 27.5 Interrupts and interrupt control.....                          | 653        |
| 27.6 Functional overview .....                                      | 654        |
| 27.6.1 Frame rate control.....                                      | 654        |
| 27.6.2 Crop window .....                                            | 654        |
| 27.6.3 Image resizing .....                                         | 655        |
| 27.6.4 Grayscale image binarization conversion .....                | 658        |
| 27.7 Data formats .....                                             | 658        |
| 27.7.1 Common CMOS video camera output formats .....                | 658        |
| 27.7.2 JPEG compressed format .....                                 | 660        |
| 27.7.3 Enhanced data management.....                                | 660        |
| 27.7.4 Data format conversion.....                                  | 660        |
| 27.8 Registers .....                                                | 661        |
| 27.8.1 DVP control register (DVP_CTRL) .....                        | 661        |
| 27.8.2 DVP status register (DVP_STS) .....                          | 663        |
| 27.8.3 DVP event status register (DVP_ESTS) .....                   | 663        |
| 27.8.4 DVP interrupt enable register (DVP_IENA).....                | 664        |
| 27.8.5 DVP interrupt status register (DVPISTS) .....                | 664        |
| 27.8.6 DVP interrupt clear register (DVP_ICLR) .....                | 664        |
| 27.8.7 DVP embedded synchronization code register (DVP_SCR) .....   | 665        |
| 27.8.8 DVP embedded synchronization unmask register (DVP_SUR) ..... | 665        |
| 27.8.9 DVP crop window start register (DVP_CWST) .....              | 666        |

|                                                                         |            |
|-------------------------------------------------------------------------|------------|
| 27.8.10 DVP crop window size register (DVP_CWSZ) .....                  | 666        |
| 27.8.11 DVP data register (DVP_DT) .....                                | 666        |
| 27.8.12 DVP advanced control register (DVP_ACTRL).....                  | 666        |
| 27.8.13 DVP enhanced horizontal scaling factor register (DVP_HSCF) ...  | 668        |
| 27.8.14 DVP enhanced vertical scaling factor register (DVP_VSCF) .....  | 668        |
| 27.8.15 DVP enhanced frame rate control factor register (DVP_FRF) ..... | 668        |
| 27.8.16 DVP binarization threshold register (DVP_BTH) .....             | 668        |
| <b>28 Qd-SPI interface (QSPI).....</b>                                  | <b>669</b> |
| 28.1 Introduction .....                                                 | 669        |
| 28.2 QSPI main features.....                                            | 669        |
| 28.3 QSPI command slave port .....                                      | 669        |
| 28.3.1 QSPI command slave port.....                                     | 669        |
| 28.3.2 CPU PIO mode.....                                                | 669        |
| 28.3.3 DMA handshake mode .....                                         | 670        |
| 28.3.4 XIP port (direct address mapping read/write) .....               | 670        |
| 28.3.5 XIP port prefetch .....                                          | 670        |
| 28.3.6 SPI device operation .....                                       | 670        |
| 28.4 QSPI registers .....                                               | 676        |
| 28.4.1 Command word 0 (CMD_W0) .....                                    | 676        |
| 28.4.2 Command word 1 (CMD_W1) .....                                    | 676        |
| 28.4.3 Command word 2 (CMD_W2) .....                                    | 677        |
| 28.4.4 Command word 3 (CMD_W3) .....                                    | 677        |
| 28.4.5 Control register (CTRL) .....                                    | 678        |
| 28.4.6 FIFO status register (FIFOSTS) .....                             | 679        |
| 28.4.7 Control register 2 (CTRL2).....                                  | 679        |
| 28.4.8 Command status register (CMDSTS) .....                           | 680        |
| 28.4.9 Read status register (RSTS) .....                                | 680        |
| 28.4.10 Flash size register (FSIZE) .....                               | 680        |
| 28.4.11 XIP command word 0 (XIP CMD_W0) .....                           | 681        |
| 28.4.12 XIP command word 1 (XIP CMD_W1) .....                           | 681        |
| 28.4.13 XIP command word 2 (XIP CMD_W2) .....                           | 682        |
| 28.4.14 XIP command word 3 (XIP CMD_W3) .....                           | 683        |
| 28.4.15 Control register (CTRL3).....                                   | 683        |
| 28.4.16 Revision register (REV) .....                                   | 683        |

|                                                                                   |            |
|-----------------------------------------------------------------------------------|------------|
| 28.4.17 Data port register (DT).....                                              | 683        |
| <b>29 EDMA controller (EDMA).....</b>                                             | <b>684</b> |
| 29.1 Introduction .....                                                           | 684        |
| 29.2 Main features .....                                                          | 684        |
| 29.3 Functional overview .....                                                    | 685        |
| 29.3.1 Flow configuration .....                                                   | 685        |
| 29.3.2 Channel selection and synchronizer .....                                   | 686        |
| 29.3.3 Handshake mechanism .....                                                  | 686        |
| 29.3.4 Arbiter .....                                                              | 686        |
| 29.3.5 Programmable data transfer width .....                                     | 687        |
| 29.3.6 FIFO and threshold .....                                                   | 688        |
| 29.3.7 Linked table transfer mechanism .....                                      | 689        |
| 29.3.8 2D transfer mechanism .....                                                | 690        |
| 29.3.9 Errors .....                                                               | 691        |
| 29.3.10 Interrupts .....                                                          | 692        |
| 29.4 DMA multiplexer (DMAMUX) .....                                               | 692        |
| 29.4.1 DMAMUX functional overview .....                                           | 692        |
| 29.4.2 DMAMUX overflow interrupts .....                                           | 694        |
| 29.5 EDMA registers .....                                                         | 696        |
| 29.5.1 DMA status register 1 (DMA_STS1).....                                      | 698        |
| 29.5.2 DMA status register 2 (DMA_STS2).....                                      | 699        |
| 29.5.3 DMA flag clear register 1 (DMA_CLR1).....                                  | 700        |
| 29.5.4 DMA flag clear register 2 (DMA_CLR2).....                                  | 701        |
| 29.5.5 DMA stream-x control register (DMA_SxCTRL) (x= 1...8).....                 | 702        |
| 29.5.6 DMA stream-x data register (DMA_SxDTCNT) (x= 1...8).....                   | 704        |
| 29.5.7 DMA stream-x peripheral address register (DMA_SxPADDR)<br>(x= 1...8) ..... | 704        |
| 29.5.8 DMA stream-x memory 0 address register (DMA_SxM0ADDR)<br>(x= 1...8) .....  | 705        |
| 29.5.9 DMA stream-x memory 1 address register (DMA_SxM1ADDR)<br>(x= 1...8) .....  | 705        |
| 29.5.10 DMA stream-x FIFO control register (DMA_SxFCTRL) (x= 1...8).705           | 705        |
| 29.5.11 DMA linked table control register (DMA_SxLLCTRL).....                     | 706        |
| 29.5.12 DMA linked table pointer register (DMA_SxLLP) (x = 1...8) .....           | 706        |

|                                                                                       |            |
|---------------------------------------------------------------------------------------|------------|
| 29.5.13 DMA 2D transfer control register (DMA_S2DCTRL) .....                          | 706        |
| 29.5.14 DMA 2D transfer count register (DMA_S2DCNT) .....                             | 706        |
| 29.5.15 DMA 2D transfer stride register (DMA_STRIDE)( x = 1...8) .....                | 707        |
| 29.5.16 DMA synchronization enable (DMA_SYNCEN).....                                  | 707        |
| 29.5.17 DMAMUX table select (DMA_MUXSEL).....                                         | 708        |
| 29.5.18 DMAMUX channel-x control register (DMA_MUXSxCTRL)<br>(x = 1...8) .....        | 708        |
| 29.5.19 DMAMUX generator-x control register (DMA_MUXGxCTRL)<br>(x = 1...8) .....      | 709        |
| 29.5.20 DMAMUX synchronization interrupt status register<br>(DMA_MUXSYNCSTS) .....    | 709        |
| 29.5.21 DMAMUX synchronization interrupt clear flag register<br>(BPR_MUXSYNCCLR)..... | 709        |
| 29.5.22 DMAMUX generator interrupt status register (DMA_MUXGSTS)                      | 710        |
| 29.5.23 DMAMUX generator interrupt clear flag register (DMA_MUXGCLR)                  | 710        |
| <b>30 Debug (DEBUG) .....</b>                                                         | <b>711</b> |
| 30.1 Debug introduction.....                                                          | 711        |
| 30.2 Debug and Trace .....                                                            | 711        |
| 30.3 I/O pin control.....                                                             | 711        |
| 30.4 DEGUB registers .....                                                            | 711        |
| 30.4.1 DEBUG device ID (DEBUG_IDCODE) .....                                           | 712        |
| 30.4.2 DEBUG control register (DEBUG_CTRL) .....                                      | 713        |
| 30.4.3 DEBUG APB1 pause register (DEBUG_APB1_PAUSE) .....                             | 713        |
| 30.4.4 DEBUG APB2 pause register (DEBUG_APB2_PAUSE) .....                             | 715        |
| 30.4.5 DEBUG SERIES ID register (DEBUG_SER_ID) .....                                  | 715        |
| <b>31 Revision history.....</b>                                                       | <b>716</b> |

## List of figures

|                                                                                   |     |
|-----------------------------------------------------------------------------------|-----|
| Figure 1-1 AT32F435/437 Series microcontrollers system architecture .....         | 45  |
| Figure 1-2 Internal block diagram of Cortex®-M4F .....                            | 46  |
| Figure 1-3 Internal block diagram of AHB BusMatrix .....                          | 47  |
| Figure 1-4 Comparison between bit-band region and its alias region: image A ..... | 48  |
| Figure 1-5 Comparison between bit-band region and its alias region: image B ..... | 48  |
| Figure 1-6 Reset process .....                                                    | 54  |
| Figure 1-7 Example of MSP and PC initialization.....                              | 55  |
| Figure 2-1 AT32F435/437 address mapping .....                                     | 57  |
| Figure 3-1 Block diagram of each power supply .....                               | 63  |
| Figure 3-2 Power-on reset/Low voltage reset waveform.....                         | 64  |
| Figure 3-3 PVM threshold and output .....                                         | 64  |
| Figure 4-1 AT32F435/437 clock tree .....                                          | 70  |
| Figure 4-2 System reset circuit.....                                              | 73  |
| Figure 5-1 Flash memory sector erase process.....                                 | 103 |
| Figure 5-2 Flash memory block erase process .....                                 | 104 |
| Figure 5-3 Flash memory mass erase process .....                                  | 105 |
| Figure 5-4 Flash memory programming process .....                                 | 106 |
| Figure 5-5 System data area erase process .....                                   | 107 |
| Figure 5-6 System data area programming process.....                              | 108 |
| Figure 6-1 GPIO basic structure.....                                              | 120 |
| Figure 6-2 IOMUX structure .....                                                  | 122 |
| Figure 8-1 External interrupt/Event controller block diagram.....                 | 151 |
| Figure 9-1 DMA block diagram .....                                                | 154 |
| Figure 9-2 Re-arbitrate after request/acknowledge.....                            | 156 |
| Figure 9-3 PWIDHT: byte, MWIDHT: half-word .....                                  | 156 |
| Figure 9-4 PWIDHT: half-word, MWIDHT: word .....                                  | 157 |
| Figure 9-5 PWIDHT: word, MWIDHT: byte .....                                       | 157 |
| Figure 9-6 DMAMUX block diagram.....                                              | 158 |
| Figure 9-7 DMAMUX request synchronized mode.....                                  | 160 |
| Figure 9-8 DMAMUX event generation .....                                          | 161 |
| Figure 10-1 CRC calculation unit block diagram .....                              | 171 |
| Figure 10-2 Diagram of byte reverse.....                                          | 172 |
| Figure 11-1 I <sup>2</sup> C bus protocol .....                                   | 174 |
| Figure 11-2 I <sup>2</sup> C function block diagram .....                         | 175 |
| Figure 11-3 Setup and hold time .....                                             | 177 |
| Figure 11-4 I <sup>2</sup> C master transmission flow.....                        | 181 |
| Figure 11-5 Transfer sequence of I <sup>2</sup> C master transmitter .....        | 182 |
| Figure 11-6 I <sup>2</sup> C master receive flow .....                            | 182 |
| Figure 11-7 Transfer sequence of I <sup>2</sup> C master receiver .....           | 183 |
| Figure 11-8 10-bit address read access when READH10=1 .....                       | 183 |
| Figure 11-9 10-bit address read access when READH10=0 .....                       | 183 |
| Figure 11-10 I <sup>2</sup> C slave transmission flow .....                       | 186 |
| Figure 11-11 I <sup>2</sup> C slave transmission timing .....                     | 186 |

|                                                                              |     |
|------------------------------------------------------------------------------|-----|
| Figure 11-12 I <sup>2</sup> C slave receive flow .....                       | 187 |
| Figure 11-13 I <sup>2</sup> C slave receive timing .....                     | 187 |
| Figure 11-14 SMBus master transmission flow .....                            | 192 |
| Figure 11-15 SMBus master transmission timing .....                          | 193 |
| Figure 11-16 SMBus master receive flow .....                                 | 193 |
| Figure 11-17 SMBus master receive timing .....                               | 194 |
| Figure 11-18 SMBus slave transmission flow .....                             | 196 |
| Figure 11-19 SMBus slave transmission timing .....                           | 196 |
| Figure 11-20 SMBus slave receive flow .....                                  | 197 |
| Figure 11-21 SMBus slave receive timing .....                                | 197 |
| Figure 12-1 USART block diagram .....                                        | 207 |
| Figure 12-2 BFF and FERR detection in LIN mode .....                         | 210 |
| Figure 12-3 Smartcard frame format .....                                     | 210 |
| Figure 12-4 IrDA DATA(3/16) – normal mode .....                              | 211 |
| Figure 12-5 Hardware flow control .....                                      | 211 |
| Figure 12-6 Mute mode using Idle line or Address mark detection .....        | 212 |
| Figure 12-7 8-bit format USART synchronous mode .....                        | 212 |
| Figure 12-8 Word length .....                                                | 213 |
| Figure 12-9 Stop bit configuration .....                                     | 214 |
| Figure 12-10 TDC/TDBE behavior when transmitting .....                       | 216 |
| Figure 12-11 Data sampling for noise detection .....                         | 219 |
| Figure 12-12 Tx/Rx swap .....                                                | 219 |
| Figure 12-13 USART interrupt map diagram .....                               | 220 |
| Figure 13-1 SPI block diagram .....                                          | 227 |
| Figure 13-2 SPI two-wire unidirectional full-duplex connection .....         | 229 |
| Figure 13-3 Single-wire unidirectional receive only in SPI master mode ..... | 229 |
| Figure 13-4 Single-wire unidirectional receive only in SPI slave mode .....  | 229 |
| Figure 13-5 Single-wire bidirectional half-duplex mode .....                 | 230 |
| Figure 13-6 Master full-duplex communications .....                          | 234 |
| Figure 13-7 Slave full-duplex communications .....                           | 235 |
| Figure 13-8 Master half-duplex transmit .....                                | 235 |
| Figure 13-9 Slave half-duplex receive .....                                  | 235 |
| Figure 13-10 Slave half-duplex transmit .....                                | 236 |
| Figure 13-11 Master half-duplex receive .....                                | 236 |
| Figure 13-12 TI mode continuous transfer .....                               | 236 |
| Figure 13-13 TI mode continuous transfer with dummy CLK .....                | 237 |
| Figure 13-14 TI mode continuous transfer with dummy CLK .....                | 237 |
| Figure 13-15 SPI interrupts .....                                            | 237 |
| Figure 13-16 I <sup>2</sup> S block diagram .....                            | 238 |
| Figure 13-17 I <sup>2</sup> S full-duplex structure .....                    | 239 |
| Figure 13-18 I <sup>2</sup> S slave device transmission .....                | 240 |
| Figure 13-19 I <sup>2</sup> S slave device reception .....                   | 240 |
| Figure 13-20 I <sup>2</sup> S master device transmission .....               | 240 |
| Figure 13-21 I <sup>2</sup> S master device reception .....                  | 241 |
| Figure 13-22 CK & MCK source in master mode .....                            | 242 |

|                                                                                            |     |
|--------------------------------------------------------------------------------------------|-----|
| Figure 13-23 Audio standard timings.....                                                   | 246 |
| Figure 13-24 I <sup>2</sup> S interrupts.....                                              | 246 |
| Figure 14-1 Basic timer block diagram.....                                                 | 253 |
| Figure 14-2 Control circuit with CK_INT divided by 1 .....                                 | 253 |
| Figure 14-3 Counter structure .....                                                        | 254 |
| Figure 14-4 Overflow event when PRBEN=0.....                                               | 254 |
| Figure 14-5 Overflow event when PRBEN=1.....                                               | 254 |
| Figure 14-6 Counter timing diagram with internal clock divided by 4 .....                  | 254 |
| Figure 14-7 General-purpose timer block diagram .....                                      | 257 |
| Figure 14-8 Count clock.....                                                               | 258 |
| Figure 14-9 Use CK_INT to drive counter with TMRx_DIV=0x0 and TMRx_PR=0x16.....            | 258 |
| Figure 14-10 Block diagram of external clock mode A.....                                   | 259 |
| Figure 14-11 Counting in external clock mode A, with PR=0x32 and DIV=0x0 .....             | 259 |
| Figure 14-12 Block diagram of external clock mode B.....                                   | 259 |
| Figure 14-13 Counting in external clock mode B, with PR=0x32 and DIV=0x0 .....             | 260 |
| Figure 14-14 Counter timing with prescaler value changing from 1 to 4 .....                | 260 |
| Figure 14-15 Counter structure .....                                                       | 261 |
| Figure 14-16 Overflow event when PRBEN=0.....                                              | 261 |
| Figure 14-17 Overflow event when PRBEN=1 .....                                             | 261 |
| Figure 14-18 Counter timing diagram with internal clock divided by 4 .....                 | 262 |
| Figure 14-19 Counter timing diagram with internal clock divided by 1 and TMRx_PR=0x32..... | 262 |
| Figure 14-20 Encoder mode structure.....                                                   | 262 |
| Figure 14-21 Example of counter behavior in encoder interface mode (encoder mode C).....   | 263 |
| Figure 14-22 Input/output channel 1 main circuit.....                                      | 264 |
| Figure 14-23 Channel 1 input stage .....                                                   | 264 |
| Figure 14-24 Example of PWM input mode configuration .....                                 | 265 |
| Figure 14-25 PWM input mode.....                                                           | 266 |
| Figure 14-26 Capture/compare channel output stage (channel 1 to 4) .....                   | 266 |
| Figure 14-27 C1ORAW toggles when counter value matches the C1DT value .....                | 267 |
| Figure 14-28 Upcounting mode and PWM mode A.....                                           | 268 |
| Figure 14-29 Up/down counting mode and PWM mode A.....                                     | 268 |
| Figure 14-30 One-pulse mode.....                                                           | 269 |
| Figure 14-31 Clearing CxORAW (PWM mode A) by EXT input.....                                | 269 |
| Figure 14-32 Example of reset mode .....                                                   | 270 |
| Figure 14-33 Example of suspend mode .....                                                 | 270 |
| Figure 14-34 Example of trigger mode .....                                                 | 270 |
| Figure 14-35 Master/slave timer connection .....                                           | 271 |
| Figure 14-36 Using master timer to start slave timer .....                                 | 271 |
| Figure 14-37 Starting master and slave timers synchronously by an external trigger.....    | 272 |
| Figure 14-38 Block diagram of general-purpose TMR9/12 .....                                | 283 |
| Figure 14-39 Block diagram of general-purpose TMR10/11/13/14 .....                         | 284 |
| Figure 14-40 Count clock.....                                                              | 284 |
| Figure 14-41 Use CK_INT to drive counter, with TMRx_DIV=0x0 and TMRx_PR=0x16 .....         | 285 |
| Figure 14-42 Block diagram of external clock mode A.....                                   | 285 |
| Figure 14-43 Counting in external clock mode A, with PR=0x32 and DIV=0x0 .....             | 286 |

|                                                                                            |     |
|--------------------------------------------------------------------------------------------|-----|
| Figure 14-44 Counter timing with prescaler value changing from 1 to 4 .....                | 286 |
| Figure 14-45 Counter structure .....                                                       | 287 |
| Figure 14-46 Overflow event when PRBEN=0.....                                              | 287 |
| Figure 14-47 Overflow event when PRBEN=1.....                                              | 288 |
| Figure 14-48 Input/output channel 1 main circuit.....                                      | 288 |
| Figure 14-49 Channel 1 input stage .....                                                   | 288 |
| Figure 14-50 Example of PWM input mode configuration .....                                 | 289 |
| Figure 14-51 PWM input mode.....                                                           | 290 |
| Figure 14-52 Capture/compare channel output stage (channel 1) .....                        | 290 |
| Figure 14-53 C1ORAW toggles when counter value matches the C1DT value .....                | 291 |
| Figure 14-54 Upcounting mode and PWM mode A.....                                           | 291 |
| Figure 14-55 One-pulse mode.....                                                           | 292 |
| Figure 14-56 Example of reset mode .....                                                   | 292 |
| Figure 14-57 Example of suspend mode .....                                                 | 292 |
| Figure 14-58 Example of trigger mode .....                                                 | 293 |
| Figure 14-59 Block diagram of advanced-control timer .....                                 | 304 |
| Figure 14-60 Count clock.....                                                              | 305 |
| Figure 14-61 Use CK_INT to drive counter, with TMRx_DIV=0x0 and TMRx_PR=0x16 .....         | 305 |
| Figure 14-62 Block diagram of external clock mode A.....                                   | 306 |
| Figure 14-63 Counting in external clock mode A, with PR=0x32 and DIV=0x0.....              | 306 |
| Figure 14-64 Block diagram of external clock mode B.....                                   | 306 |
| Figure 14-65 Counting in external clock mode B, with PR=0x32 and DIV=0x0 .....             | 307 |
| Figure 14-66 Counter timing with prescaler value changing from 1 to 4 .....                | 307 |
| Figure 14-67 Counter structure .....                                                       | 308 |
| Figure 14-68 Overflow event when PRBEN=0.....                                              | 308 |
| Figure 14-69 Overflow event when PRBEN=1 .....                                             | 308 |
| Figure 14-70 Counter timing diagram with internal clock divided by 4 .....                 | 309 |
| Figure 14-71 Counter timing diagram with internal clock divided by 1 and TMRx_PR=0x32..... | 309 |
| Figure 14-72 OVFIF in upcounting mode and up/down counting mode .....                      | 310 |
| Figure 14-73 Encoder mode structure.....                                                   | 310 |
| Figure 14-74 Example of encoder interface mode C .....                                     | 311 |
| Figure 14-75 Input/output channel 1 main circuit .....                                     | 312 |
| Figure 14-76 Channel 1 input stage .....                                                   | 312 |
| Figure 14-77 Example of PWM input mode configuration .....                                 | 313 |
| Figure 14-78 PWM input mode.....                                                           | 314 |
| Figure 14-79 Channel output stage (channel 1 to 3).....                                    | 314 |
| Figure 14-80 Channel 4 output stage .....                                                  | 314 |
| Figure 14-81 C1ORAW toggles when counter value matches the C1DT value .....                | 315 |
| Figure 14-82 Upcounting mode and PWM mode A.....                                           | 316 |
| Figure 14-83 Up/down counting mode and PWM mode A.....                                     | 316 |
| Figure 14-84 One-pulse mode.....                                                           | 316 |
| Figure 14-85 Clearing CxORAW(PWM mode A) by EXT input.....                                 | 317 |
| Figure 14-86 Complementary output with dead-time insertion .....                           | 317 |
| Figure 14-87 TMR output control.....                                                       | 318 |
| Figure 14-88 Example of TMR break function.....                                            | 319 |

|                                                                |     |
|----------------------------------------------------------------|-----|
| Figure 14-89 Example of reset mode .....                       | 319 |
| Figure 14-90 Example of suspend mode .....                     | 320 |
| Figure 14-91 Example of trigger mode .....                     | 320 |
| Figure 15-1 Window watchdog block diagram .....                | 335 |
| Figure 15-2 Window watchdog timing diagram .....               | 336 |
| Figure 16-1 WDT block diagram.....                             | 339 |
| Figure 17-1 ERTC block diagram .....                           | 341 |
| Figure 18-1 ADC1 block diagram .....                           | 359 |
| Figure 18-2 ADC basic operation process.....                   | 361 |
| Figure 18-3 ADC power-on and calibration .....                 | 362 |
| Figure 18-4 Sequence mode .....                                | 364 |
| Figure 18-5 Preempted group auto conversion mode.....          | 364 |
| Figure 18-6 Repetition mode .....                              | 365 |
| Figure 18-7 Partition mode .....                               | 365 |
| Figure 18-8 ADABRT timing diagram .....                        | 366 |
| Figure 18-9 Ordinary oversampling restart mode selection ..... | 367 |
| Figure 18-10 Ordinary oversampling trigger mode .....          | 368 |
| Figure 18-11 Oversampling of preempted group of channels.....  | 368 |
| Figure 18-12 Data alignment .....                              | 369 |
| Figure 18-13 Block diagram of master/slave mode.....           | 370 |
| Figure 18-14 Regular simultaneous mode .....                   | 372 |
| Figure 18-15 Regular simultaneous mode .....                   | 372 |
| Figure 18-16 Alternate preempted trigger mode .....            | 373 |
| Figure 18-17 Regular shift mode .....                          | 373 |
| Figure 18-18 Regular shift mode and DMA mode 2.....            | 374 |
| Figure 19-1 DAC1/DAC2 block diagram .....                      | 392 |
| Figure 19-2 LFSR register calculation algorithm.....           | 394 |
| Figure 19-3 Triangular-wave generation .....                   | 394 |
| Figure 20-1 Bit timing.....                                    | 400 |
| Figure 20-2 Transmit interrupt generation .....                | 402 |
| Figure 20-3 Transmit interrupt generation .....                | 403 |
| Figure 20-4 Receive interrupt 0 generation.....                | 403 |
| Figure 20-5 Receive interrupt 1 generation.....                | 403 |
| Figure 20-6 Status error interrupt generation.....             | 403 |
| Figure 20-7 CAN block diagram .....                            | 404 |
| Figure 20-8 32-bit identifier mask mode .....                  | 406 |
| Figure 20-9 32-bit identifier list mode .....                  | 406 |
| Figure 20-10 16-bit identifier mask mode .....                 | 406 |
| Figure 20-11 16-bit identifier list mode .....                 | 407 |
| Figure 20-12 Transmit mailbox status .....                     | 408 |
| Figure 20-13 Receive FIFO status .....                         | 409 |
| Figure 20-14 Transmit and receive mailboxes .....              | 420 |
| Figure 21-1 Block diagram of OTGFS structure.....              | 424 |
| Figure 21-2 OTGFS interrupt hierarchy.....                     | 426 |
| Figure 21-3 Writing the transmit FIFO .....                    | 431 |

|                                                                                                             |     |
|-------------------------------------------------------------------------------------------------------------|-----|
| Figure 21-4 Reading the receive FIFO.....                                                                   | 432 |
| Figure 21-5 HFIR behavior when HFIRRLDCTRL=0x0 .....                                                        | 433 |
| Figure 21-6 HFIR behavior when HFIRRLDCTRL=0x1 .....                                                        | 434 |
| Figure 21-7 Example of common Bulk/Control OUT/SETUP and Bulk/Control IN transfer.....                      | 437 |
| Figure 21-8 Example of common interrupt OUT/IN transfers .....                                              | 441 |
| Figure 21-9 Example of common synchronous OUT/IN transfers .....                                            | 444 |
| Figure 21-10 Read receive FIFO.....                                                                         | 449 |
| Figure 21-11 SETUP data packet flowchart .....                                                              | 451 |
| Figure 21-12 BULK OUT transfer block diagram .....                                                          | 455 |
| Figure 21-13 CSR memory map.....                                                                            | 461 |
| Figure 22-1 ACC interrupt mapping diagram.....                                                              | 499 |
| Figure 22-2 ACC block diagram .....                                                                         | 500 |
| Figure 22-3 Cross-return algorithm .....                                                                    | 501 |
| Figure 23-1 IRTMR block diagram .....                                                                       | 505 |
| Figure 24-1 XMC block diagram.....                                                                          | 508 |
| Figure 24-2 XMC memory banks.....                                                                           | 510 |
| Figure 24-3 NOR/PSRAM mode 1 read access.....                                                               | 515 |
| Figure 24-4 NOR/PSRAM mode 1 write access .....                                                             | 515 |
| Figure 24-5 NOR/PSRAM mode 2 read access.....                                                               | 516 |
| Figure 24-6 NOR/PSRAM mode 2 write access .....                                                             | 517 |
| Figure 24-7 NOR/PSRAM mode A read access.....                                                               | 518 |
| Figure 24-8 NOR/PSRAM mode A write access .....                                                             | 519 |
| Figure 24-9 NOR/PSRAM mode B read access .....                                                              | 520 |
| Figure 24-10 NOR/PSRAM mode B write access .....                                                            | 521 |
| Figure 24-11 NOR/PSRAM mode C read access .....                                                             | 522 |
| Figure 24-12 NOR/PSRAM mode C write access.....                                                             | 523 |
| Figure 24-13 NOR/PSRAM mode D read access .....                                                             | 524 |
| Figure 24-14 NOR/PSRAM mode D write access.....                                                             | 525 |
| Figure 24-15 NOR/PSRAM multiplexed mode read access .....                                                   | 526 |
| Figure 24-16 NOR/PSRAM multiplexed mode write access .....                                                  | 527 |
| Figure 24-17 NOR/PSRAM synchronous multiplexed mode read access.....                                        | 528 |
| Figure 24-18 NOR/PSRAM synchronous multiplexed mode write access .....                                      | 529 |
| Figure 24-19 NAND read access.....                                                                          | 530 |
| Figure 24-20 NAND wait functionality .....                                                                  | 531 |
| Figure 24-21 PC card read/write .....                                                                       | 533 |
| Figure 24-22 SDRAM write access waveforms (Trcd=2, 9 consecutive write access).....                         | 534 |
| Figure 24-23 SDRAM read access without using read FIFO (Trcd=2,CL=3, and 4 consecutive read accesses) ..... | 535 |
| Figure 25-1 SDIO “no response” and “response” operations.....                                               | 552 |
| Figure 25-2 SDIO multiple block read operation .....                                                        | 552 |
| Figure 25-3 SDIO multiple block write operation.....                                                        | 552 |
| Figure 25-4 SDIO sequential read operation.....                                                             | 553 |
| Figure 25-5 SDIO sequential write operation .....                                                           | 553 |
| Figure 25-6 SDIO block diagram .....                                                                        | 565 |
| Figure 25-7 Command channel state machine (CCSM) .....                                                      | 567 |

|                                                                                   |     |
|-----------------------------------------------------------------------------------|-----|
| Figure 25-8 SDIO command transfer .....                                           | 568 |
| Figure 25-9 Data channel state machine (DCSM) .....                               | 568 |
| Figure 26-1 Block diagram of EMAC .....                                           | 580 |
| Figure 26-2 SMI interface signals.....                                            | 582 |
| Figure 26-3 MII signals .....                                                     | 583 |
| Figure 26-4 Reduced media-independent interface signals .....                     | 584 |
| Figure 26-5 MII clock sources (provided by CLKOUT pin).....                       | 585 |
| Figure 26-6 MII clock sources (provided by an external oscillator).....           | 585 |
| Figure 26-7 RMII clock sources (provided by an external crystal oscillator).....  | 585 |
| Figure 26-8 MAC frame format.....                                                 | 586 |
| Figure 26-9 Tagged MAC frame format.....                                          | 587 |
| Figure 26-10 Descriptor for ring and chain structure.....                         | 594 |
| Figure 26-11 Transmit descriptors .....                                           | 597 |
| Figure 26-12 RXDMA descriptor structure .....                                     | 603 |
| Figure 26-13 Wakeup frame filter register .....                                   | 608 |
| Figure 26-14 System time update using the fine correction method .....            | 611 |
| Figure 26-15 PTP trigger output to TMR2 ITR1 connection.....                      | 612 |
| Figure 26-16 PPS output .....                                                     | 613 |
| Figure 26-17 Ethernet interrupts.....                                             | 614 |
| Figure 26-18 Ethernet MAC remote wakeup frame filter register (EMAC_MACRWFF)..... | 623 |
| Figure 27-1 DVP block diagram .....                                               | 647 |
| Figure 27-2 CMOS video camera output in Frame start type .....                    | 648 |
| Figure 27-3 CMOS video camera output in Frame valid type .....                    | 648 |
| Figure 27-4 FS/FE/LS/LE frame composition.....                                    | 649 |
| Figure 27-5 SAV/EAV frame composition.....                                        | 650 |
| Figure 27-6 Block diagram in single frame capture mode .....                      | 651 |
| Figure 27-7 Block diagram in continuous capture mode.....                         | 652 |
| Figure 27-8 PDL configuration and data output packing.....                        | 653 |
| Figure 27-9 Block diagram of frame rate control feature.....                      | 654 |
| Figure 27-10 Crop window block diagram .....                                      | 655 |
| Figure 27-11 Image resizing block diagram .....                                   | 655 |
| Figure 27-12 LCDC/LCDS and frame structure .....                                  | 656 |
| Figure 27-13 PCDC/PCDS and line structure .....                                   | 657 |
| Figure 27-14 RGB565-format data capture and packing .....                         | 658 |
| Figure 27-15 RGB555-format data capture and packing .....                         | 659 |
| Figure 27-16 YUV422-format data capture and packing.....                          | 659 |
| Figure 27-17 Y8 (Y-only)-format data capture and packing .....                    | 660 |
| Figure 27-18 YUV422 format to Y8 (Y-only) format .....                            | 661 |
| Figure 28-1 Function block diagram .....                                          | 669 |
| Figure 28-2 DMA handshake mode.....                                               | 670 |
| Figure 28-3 Write enable .....                                                    | 671 |
| Figure 28-4 Page programming.....                                                 | 671 |
| Figure 28-5 Status read .....                                                     | 671 |
| Figure 28-6 Data read.....                                                        | 671 |
| Figure 28-7 Quick read dual output command .....                                  | 672 |

|                                                                                                  |     |
|--------------------------------------------------------------------------------------------------|-----|
| Figure 28-8 Quick read dual-wire I/O .....                                                       | 672 |
| Figure 28-9 Quick read quad output.....                                                          | 673 |
| Figure 28-10 Quick read quad I/O command.....                                                    | 673 |
| Figure 29-1 Block diagram.....                                                                   | 684 |
| Figure 29-2 Channel select and synchronizer.....                                                 | 686 |
| Figure 29-3 Re-arbitrate after Request/Acknowledge.....                                          | 687 |
| Figure 29-4 Example of packing mechanism .....                                                   | 687 |
| Figure 29-5 Example of unpacking mechanism .....                                                 | 688 |
| Figure 29-6 Example of PINCOS .....                                                              | 688 |
| Figure 29-7 Descriptor format.....                                                               | 689 |
| Figure 29-8 Linked list pointers .....                                                           | 689 |
| Figure 29-9 Example of a 2D transfer (source side is managed by a peripheral controller) .....   | 690 |
| Figure 29-10 Example of a 2D transfer (destination side is managed by a memory controller) ..... | 691 |
| Figure 29-11 DMAMUX block diagram .....                                                          | 693 |
| Figure 29-12 DMAMUX synchronized mode.....                                                       | 695 |
| Figure 29-13 DMAMUX event generation .....                                                       | 695 |

## List of tables

|                                                                                    |     |
|------------------------------------------------------------------------------------|-----|
| Table 1-1 Bit-band address mapping in SRAM .....                                   | 49  |
| Table 1-2 Bit-band address mapping in the peripheral area .....                    | 49  |
| Table 1-3 AT32F435/437 series vector table .....                                   | 50  |
| Table 1-4 List of abbreviations for registers.....                                 | 56  |
| Table 1-5 List of abbreviations for registers.....                                 | 56  |
| Table 2-1 Peripheral boundary address .....                                        | 60  |
| Table 3-1 PW register map and reset values .....                                   | 67  |
| Table 4-1 CRM register map and reset values.....                                   | 73  |
| Table 5-1 Flash memory architecture (4032 K) .....                                 | 96  |
| Table 5-2 Flash memory architecture (1024 K) .....                                 | 97  |
| Table 5-3 Flash memory architecture (448 K) .....                                  | 97  |
| Table 5-4 Flash memory architecture (256 K) .....                                  | 98  |
| Table 5-5 User system data area.....                                               | 98  |
| Table 5-6 Extended system options.....                                             | 101 |
| Table 5-7 Flash memory access limit .....                                          | 109 |
| Table 5-8 Flash memory interface—Register map and reset value .....                | 111 |
| Table 6-1 Port A multiplexed function configuration with GPIOA_MUX* register.....  | 124 |
| Table 6-2 Port B multiplexed function configuration with GPIOB_MUX* register ..... | 126 |
| Table 6-3 Port C multiplexed function configuration with GPIOC_MUX* register ..... | 128 |
| Table 6-4 Port D multiplexed function configuration with GPIOD_MUX* register ..... | 130 |
| Table 6-5 Port E multiplexed function configuration with GPIOE_MUX* register ..... | 132 |
| Table 6-6 Port F multiplexed function configuration with GPIOF_MUX* register ..... | 134 |
| Table 6-7 Port G multiplexed function configuration with GPIOG_MUX* register ..... | 136 |
| Table 6-8 Port H multiplexed function configuration with GPIOH_MUX* register ..... | 138 |
| Table 6-9 Pins owned by hardware .....                                             | 138 |
| Table 6-10 GPIO register map and reset values .....                                | 139 |
| Table 7-1 SCFG register map and reset values .....                                 | 143 |
| Table 8-1 External interrupt/Event controller register map and reset value .....   | 152 |
| Table 9-1 DMA error event.....                                                     | 157 |
| Table 9-2 DMA interrupt requests .....                                             | 157 |
| Table 9-3 Flexible DMA1/DMA2 request mapping .....                                 | 159 |
| Table 9-4 DMAMUX EXINT LINE for trigger input and synchronized input .....         | 160 |
| Table 9-5 DMA register map and reset value .....                                   | 161 |
| Table 10-1 CRC register map and reset value .....                                  | 172 |
| Table 11-1 I <sup>2</sup> C timing specifications .....                            | 178 |
| Table 11-2 I <sup>2</sup> C configuration table.....                               | 179 |
| Table 11-3 SMBus timeout specification .....                                       | 189 |
| Table 11-4 SMBus timeout detection configuration .....                             | 189 |
| Table 11-5 SMBus mode configuration .....                                          | 190 |
| Table 11-6 I <sup>2</sup> C error events .....                                     | 198 |
| Table 11-7 I <sup>2</sup> C interrupt requests .....                               | 200 |
| Table 11-8 I <sup>2</sup> C register map and reset values .....                    | 200 |
| Table 12-1 Error calculation for programmed baud rate .....                        | 215 |

|                                                                                                     |     |
|-----------------------------------------------------------------------------------------------------|-----|
| Table 12-2 Data sampling over start bit and noise detection .....                                   | 218 |
| Table 12-3 Data sampling over valid data and noise detection.....                                   | 218 |
| Table 12-4 USART interrupt request .....                                                            | 220 |
| Table 12-5 USART register map and reset value .....                                                 | 221 |
| Table 13-1 Audio frequency precision using system clock.....                                        | 243 |
| Table 13-2 SPI register map and reset value .....                                                   | 247 |
| Table 14-1 TMR functional comparison.....                                                           | 252 |
| Table 14-2 TMR6 and TMR7— register table and reset value.....                                       | 255 |
| Table 14-3 TMRx internal trigger connection.....                                                    | 260 |
| Table 14-4 Counting direction versus encoder signals.....                                           | 263 |
| Table 14-5 TMRx register map and reset value .....                                                  | 272 |
| Table 14-6 Standard CxOUT channel output control bit.....                                           | 280 |
| Table 14-7 TMRx internal trigger connection.....                                                    | 286 |
| Table 14-8 TMRx register map and reset value .....                                                  | 293 |
| Table 14-9 Standard CxOUT channel output control bit.....                                           | 298 |
| Table 14-10 TMRx register map and reset value .....                                                 | 299 |
| Table 14-11 Standard CxOUT channel output control bit.....                                          | 303 |
| Table 14-12 TMRx internal trigger connection.....                                                   | 307 |
| Table 14-13 Counting direction versus encoder signals.....                                          | 311 |
| Table 14-14 TMR1 and TMR8 register map and reset value .....                                        | 321 |
| Table 14-15 Complementary output channel CxOUT and CxCOUT control bits with break function.....     | 330 |
| Table 15-1 Minimum and maximum timeout value when PCLK1=72 MHz.....                                 | 336 |
| Table 15-2 WWDT register map and reset value .....                                                  | 336 |
| Table 16-1 WDT timeout period (LICK=40kHz).....                                                     | 339 |
| Table 16-2 WDT register and reset value .....                                                       | 339 |
| Table 17-1 RTC register map and reset values.....                                                   | 342 |
| Table 17-2 ERTC low-power mode wakeup .....                                                         | 348 |
| Table 17-3 Interrupt control bits .....                                                             | 348 |
| Table 17-4 ERTC register map and reset values .....                                                 | 348 |
| Table 18-1 Trigger sources for ordinary channels .....                                              | 362 |
| Table 18-2 Trigger sources for preempted channels.....                                              | 363 |
| Table 18-3 Correlation between maximum cumulative data, oversampling multiple and shift digits..... | 366 |
| Table 18-4 Master/slave DMA mode.....                                                               | 371 |
| Table 18-5 ADC register map and reset values.....                                                   | 374 |
| Table 19-1 Trigger source selection.....                                                            | 393 |
| Table 19-2 DAC register map and reset values .....                                                  | 395 |
| Table 20-1 CAN register map and reset values .....                                                  | 410 |
| Table 21-1 OTGFS input/output pins .....                                                            | 425 |
| Table 21-2 OTGFS transmit FIFO SRAM allocation .....                                                | 427 |
| Table 21-3 OTGFS internal storage space allocation .....                                            | 429 |
| Table 21-4 OTGFS register map and reset values .....                                                | 462 |
| Table 21-5 Minimum duration for software disconnect.....                                            | 486 |
| Table 22-1 ACC interrupt requests .....                                                             | 499 |
| Table 22-2 ACC register map and reset values.....                                                   | 502 |
| Table 24-1 NOR/PSRAM pins .....                                                                     | 508 |

|                                                                                                          |     |
|----------------------------------------------------------------------------------------------------------|-----|
| Table 24-2 NAND pins .....                                                                               | 509 |
| Table 24-3 PC card pins .....                                                                            | 509 |
| Table 24-4 SDRAM pins .....                                                                              | 509 |
| Table 24-5 Memory bank selection.....                                                                    | 511 |
| Table 24-6 8-bit SDRAM address mapping .....                                                             | 511 |
| Table 24-7 16-bit SDRAM address mapping .....                                                            | 512 |
| Table 24-8 Pin signals for NOR and PSRAM .....                                                           | 512 |
| Table 24-9 Address translation between HADDR and external memory .....                                   | 513 |
| Table 24-10 Data access width vs. external memory data width .....                                       | 513 |
| Table 24-11 NOR/PSRAM parameter registers.....                                                           | 514 |
| Table 24-12 Mode 1— SRAM/NOR Flash chip select control register (XMC_BK1CTRL) configuration..            | 514 |
| Table 24-13 Mode 1— SRAM/NOR Flash chip select timing register (XMC_BK1TMG) configuration ...            | 514 |
| Table 24-14 Mode 2 — SRAM/NOR Flash chip select control register .....                                   | 515 |
| Table 24-15 Mode 2 — SRAM/NOR Flash chip select timing register.....                                     | 516 |
| Table 24-16 Mode A— SRAM/NOR Flash chip select control register .....                                    | 517 |
| Table 24-17 Mode A— SRAM/NOR Flash chip select timing register .....                                     | 518 |
| Table 24-18 Mode A— SRAM/NOR Flash write timing register .....                                           | 518 |
| Table 24-19 Mode B— SRAM/NOR Flash chip select register .....                                            | 519 |
| Table 24-20 Mode B— SRAM/NOR Flash chip select timing register .....                                     | 520 |
| Table 24-21 Mode B— SRAM/NOR Flash write timing register.....                                            | 520 |
| Table 24-22 Mode C— SRAM/NOR Flash chip select register .....                                            | 521 |
| Table 24-23 Mode C—SRAM/NOR Flash chip select timing register .....                                      | 522 |
| Table 24-24 Mode C— SRAM/NOR Flash write timing register.....                                            | 522 |
| Table 24-25 Mode D— SRAM/NOR Flash chip select register (XMC_BK1CTRL) configuration .....                | 523 |
| Table 24-26 Mode D—SRAM/NOR Flash chip select timing register .....                                      | 524 |
| Table 24-27 Mode D— SRAM/NOR Flash write timing register.....                                            | 524 |
| Table 24-28 Multiplexed mode — SRAM/NOR Flash chip select control register .....                         | 525 |
| Table 24-29 Multiplexed mode—SRAM/NOR Flash chip select timing register (XMC_BK1TMG) configuration ..... | 526 |
| Table 24-30 Synchronous mode — SRAM/NOR Flash chip select control register .....                         | 527 |
| Table 24-31 Synchronous mode—SRAM/NOR Flash chip select timing register (XMC_BK1TMG).....                | 528 |
| Table 24-32 Typical pin signals for NAND Flash .....                                                     | 529 |
| Table 24-33 Data access width vs. external memory data width .....                                       | 530 |
| Table 24-34 NAND parameter registers .....                                                               | 530 |
| Table 24-35 lists the ECC result bits corresponding to the number of bytes .....                         | 531 |
| Table 24-36 Typical pin signals for PC card .....                                                        | 532 |
| Table 24-37 Access data width and PC card data width .....                                               | 532 |
| Table 24-38 PC card parameter register .....                                                             | 532 |
| Table 24-39 XMC register address mapping .....                                                           | 536 |
| Table 25-1 Lock/unlock command structure.....                                                            | 556 |
| Table 25-2 Commands.....                                                                                 | 558 |
| Table 25-3 Data block read commands.....                                                                 | 559 |
| Table 25-4 Data stream read/write commands .....                                                         | 560 |
| Table 25-5 Data block write commands .....                                                               | 560 |
| Table 25-6 Block-based write protect commands .....                                                      | 560 |

|                                                                             |     |
|-----------------------------------------------------------------------------|-----|
| Table 25-7 Erase commands .....                                             | 561 |
| Table 25-8 I/O mode commands .....                                          | 561 |
| Table 25-9 Card lock commands .....                                         | 561 |
| Table 25-10 Application-specific commands .....                             | 562 |
| Table 25-11 R1 response .....                                               | 562 |
| Table 25-12 R2 response .....                                               | 563 |
| Table 25-13 R3 response .....                                               | 563 |
| Table 25-14 R4 response .....                                               | 563 |
| Table 25-15 R4b response .....                                              | 563 |
| Table 25-16 R5 response .....                                               | 563 |
| Table 25-17 R6 response .....                                               | 564 |
| Table 25-18 SDIO pin definitions .....                                      | 565 |
| Table 25-19 Command formats .....                                           | 566 |
| Table 25-20 Short response format .....                                     | 566 |
| Table 25-21 Long response format .....                                      | 566 |
| Table 25-22 Command path status flags .....                                 | 567 |
| Table 25-23 Data token formats .....                                        | 569 |
| Table 25-24 A summary of the SDIO registers .....                           | 571 |
| Table 25-25 Response type and SDIO_RSPx register .....                      | 574 |
| Table 26-1 shows the clock range .....                                      | 582 |
| Table 26-2 Transmit interface signal encode .....                           | 584 |
| Table 26-3 Receive interface signal encode .....                            | 584 |
| Table 26-4 Ethernet peripheral pin configuration .....                      | 586 |
| Table 26-5 Destination address filtering .....                              | 589 |
| Table 26-6 Source address filtering .....                                   | 589 |
| Table 26-7 Receive descriptor 0 .....                                       | 604 |
| Table 26-8 Ethernet register map and its reset values .....                 | 614 |
| Table 27-1 DVP pin use in hardware synchronization mode .....               | 649 |
| Table 27-2 DVP pin use in embedded synchronization mode .....               | 650 |
| Table 27-3 DVP register configuration and DVP_D pin use .....               | 651 |
| Table 27-4 Enhanced features and DVP data formats supported .....           | 660 |
| Table 27-5 DVP register map and reset values .....                          | 661 |
| Table 28-1 SPI register map and reset values .....                          | 676 |
| Table 29-1 DMA error events .....                                           | 691 |
| Table 29-2 DMA interrupts .....                                             | 692 |
| Table 29-3 EDMA flexible request mapping .....                              | 693 |
| Table 29-4 DMAMUX EXINT LINE for trigger input and synchronized input ..... | 694 |
| Table 29-5 BPR register map and reset values .....                          | 696 |
| Table 30-1 DEBUG register address and reset value .....                     | 711 |

# 1 System architecture

AT32F435/437 series microcontrollers incorporates a 32-bit ARM® Cortex®-M4F processor core, multiple 16-bit and 32-bit timers, Infrared Transmitter (IRTMR), DMA controller, EDMA controller, ERTC, communication interfaces such as SPI, QSPI, I<sup>2</sup>C, USART/UART and SDIO, CAN bus controller, external memory controller (XMC), USB2.0 full-speed interfaces, Ethernet MAC, parallel digital camera interface, HICK with automatic clock calibration (ACC), 12-bit ADC, 12-bit DAC, 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 AT32F435/437 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 low gate count, low interrupt latency, and low-cost debug. It supports DSP instruction set and FPU, and 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 BusMatrix

Figure 1-3 shows the block diagram of AHB BusMatrix.

Figure 1-3 Internal block diagram of AHB BusMatrix.



### 1.1.3 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 1M bytes of SRAM and the least significant 1Mbytes 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 a 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-4 Comparison between bit-band region and its alias region: image A



Figure 1-5 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:

The lowest 1 Mbyte of the SRAM: 0x2000\_0000~0x200F\_FFFF

The lowest 1 Mbyte of 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 do:

- 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.4 Interrupt and exception vectors

Table 1-3 AT32F435/437 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) is 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 | Debug Monitor |                 | 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  | EDMA data flow1 | EDMA data flow1 global interrupt                                                | 0x0000_006C                 |
| 12   | 19           | Configurable  | EDMA data flow2 | EDMA data flow2 global interrupt                                                | 0x0000_0070                 |
| 13   | 20           | Configurable  | EDMA data flow3 | EDMA data flow3 global interrupt                                                | 0x0000_0074                 |
| 14   | 21           | Configurable  | EDMA data flow4 | EDMA data flow4 global interrupt                                                | 0x0000_0078                 |

|    |    |              |                         |                                                            |             |
|----|----|--------------|-------------------------|------------------------------------------------------------|-------------|
| 15 | 22 | Configurable | EDMA data flow5         | EDMA data flow5 global interrupt                           | 0x0000_007C |
| 16 | 23 | Configurable | EDMA data flow6         | EDMA data flow6 global interrupt                           | 0x0000_0080 |
| 17 | 24 | Configurable | EDMA data flow7         | EDMA data flow7 global interrupt                           | 0x0000_0084 |
| 18 | 25 | Configurable | ADC1_2_3                | ADC1, ADC2 and ADC3 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 break interrupt and TMR9 global interrupt             | 0x0000_00A0 |
| 25 | 32 | Configurable | TMR1_OVF_TMR10          | TMR1 overflow and TMR10 global interrupt                   | 0x0000_00A4 |
| 26 | 33 | Configurable | TMR1_TRG_HALL_T<br>MR11 | 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_I2S2EXT            | SPI2 and IS2EXT 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] global interrupt                        | 0x0000_00E0 |
| 41 | 48 | Configurable | ERTCAlarm               | ERTC alarm through EXINT interrupt                         | 0x0000_00E4 |
| 42 | 49 | Configurable | OTGFS1 wakeup           | OTGFS1 standby wakeup through EXINT interrupt              | 0x0000_00E8 |
| 43 | 50 | Configurable | TMR8_BRK_TMR12          | TMR8 break interrupt and TMR12 global interrupt            | 0x0000_00EC |
| 44 | 51 | Configurable | TMR8_OVF_TMR13          | TMR8 overflow interrupt and TMR13 global interrupt         | 0x0000_00F0 |
| 45 | 52 | Configurable | TMR8_TRG_HALL_T<br>MR14 | TMR8 trigger and HALL interrupt and TMR14 global interrupt | 0x0000_00F4 |
| 46 | 53 | Configurable | TMR8_CH                 | TMR8 channel interrupt                                     | 0x0000_00F8 |
| 47 | 54 | Configurable | EDMA data flow8         | EDMA data flow8 global interrupt                           | 0x0000_00FC |
| 48 | 55 | Configurable | XMC                     | XMC global interrupt                                       | 0x0000_0100 |

|    |    |              |                        |                                                        |             |
|----|----|--------------|------------------------|--------------------------------------------------------|-------------|
| 49 | 56 | Configurable | SDIO1                  | SDIO1 global interrupt                                 | 0x0000_0104 |
| 50 | 57 | Configurable | TMR5                   | TMR5 global interrupt                                  | 0x0000_0108 |
| 51 | 58 | Configurable | SPI3_I2S3EXT           | SPI3 and I2S3EXT global interrupt                      | 0x0000_010C |
| 52 | 59 | Configurable | UART4                  | UART4 global interrupt                                 | 0x0000_0110 |
| 53 | 60 | Configurable | UART5                  | UART5 global interrupt                                 | 0x0000_0114 |
| 54 | 61 | Configurable | TMR6_DAC               | TMR6 global interrupt<br>DAC1 and DAC2 underflow error | 0x0000_0118 |
| 55 | 62 | Configurable | TMR7                   | TMR7 global interrupt                                  | 0x0000_011C |
| 56 | 63 | Configurable | DMA1 channel1          | DMA1 channel1 global interrupt                         | 0x0000_0120 |
| 57 | 64 | Configurable | DMA1 channel2          | DMA1 channel2 global interrupt                         | 0x0000_0124 |
| 58 | 65 | Configurable | DMA1 channel3          | DMA1 channel3 global interrupt                         | 0x0000_0128 |
| 59 | 66 | Configurable | DMA1 channel4          | DMA1 channel4 global interrupt                         | 0x0000_012C |
| 60 | 67 | Configurable | DMA1 channel5          | DMA1 channel5 global interrupt                         | 0x0000_0130 |
| 61 | 68 | Configurable | EMAC <sup>2</sup>      | Ethernet global interrupt                              | 0x0000_0134 |
| 62 | 69 | Configurable | EMAC_WKUP <sup>2</sup> | Ethernet wakeup interrupt through EXINT                | 0x0000_0138 |
| 63 | 70 | Configurable | CAN2_TX                | CAN2 TX interrupt                                      | 0x0000_013C |
| 64 | 71 | Configurable | CAN2_RX0               | CAN2 RX0 interrupt                                     | 0x0000_0140 |
| 65 | 72 | Configurable | CAN2_RX1               | CAN2 RX1 interrupt                                     | 0x0000_0144 |
| 66 | 73 | Configurable | CAN2_SE                | CAN2 status error interrupt                            | 0x0000_0148 |
| 67 | 74 | Configurable | OTGFS1                 | OTGFS1 CAN2 status error interrupt                     | 0x0000_014C |
| 68 | 75 | Configurable | DMA1 channel6          | DMA1 channel6 global interrupt                         | 0x0000_0150 |
| 69 | 76 | Configurable | DMA1 chaanel7          | DMA1 channel7 global interrupt                         | 0x0000_0154 |
| 70 | 77 | Configurable | -                      | -                                                      | 0x0000_0158 |
| 71 | 78 | Configurable | USART6                 | USART6 global interrupt                                | 0x0000_015C |
| 72 | 79 | Configurable | I2C3_EVT               | I2C2 event interrupt                                   | 0x0000_0160 |
| 73 | 80 | Configurable | I2C3_ERR               | I2C2 error interrupt                                   | 0x0000_0164 |
| 74 | 81 | Configurable | -                      | -                                                      | 0x0000_0168 |
| 75 | 82 | Configurable | -                      | -                                                      | 0x0000_016C |
| 76 | 83 | Configurable | OTGFS2 wakeup          | OTGFS2 standby wakeup interrupt through EXINT          | 0x0000_0170 |
| 77 | 84 | Configurable | OTGFS2                 | OTGFS2 global interrupt                                | 0x0000_0174 |
| 78 | 85 | Configurable | DVP                    | DVP global interrupt                                   | 0x0000_0178 |
| 79 | 86 | -            | -                      | -                                                      | 0x0000_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 | Configu      | UART8                  | UART8 global interrupt                                 | 0x0000_018C |

|     |     | table        |                |                                  |                   |
|-----|-----|--------------|----------------|----------------------------------|-------------------|
| 84  | 91  | Configurable | SPI4           | SPI4 global interrupt            | 0x0000_0190       |
| 85  | 92  | -            | -              | -                                | 0x0000_0194       |
| 86  | 93  | -            | -              | -                                | 0x0000_0198       |
| 87  | 94  | -            | -              | -                                | 0x0000_019C       |
| 88  | 95  | -            | -              | -                                | 0x0000_01A0       |
| 89  | 96  | -            | -              | -                                | 0x0000_01A44<br>4 |
| 90  | 97  | -            | -              | -                                | 0x0000_01A8       |
| 91  | 98  | Configurable | QSPI2          | QSPI2 global interrupt           | 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 | Configurable | SDIO2          | SDIO2 global interrupt           | 0x0000_01D8       |
| 103 | 110 | Configurable | ACC            | ACC global interrupt             | 0x0000_01DC       |
| 104 | 111 | Configurable | TMR20_BRK      | TMR20 break interrupt            | 0x0000_01E0       |
| 105 | 112 | Configurable | TMR20_OVF      | TMR20 overflow interrupt         | 0x0000_01E4       |
| 106 | 113 | Configurable | TMR20_TRG_HALL | TMR20 trigger and HALL interrupt | 0x0000_01E8       |
| 107 | 114 | Configurable | TMR20_CH       | TMR20 channel interrupt          | 0x0000_01EC       |
| 108 | 115 | Configurable | DMA2 channel0  | DMA2 channel0 global interrupt   | 0x0000_01F0       |
| 109 | 116 | Configurable | DMA2 channel1  | DMA2 channel1 global interrupt   | 0x0000_01F4       |
| 110 | 117 | Configurable | DMA2 channel2  | DMA2 channel2 global interrupt   | 0x0000_01F8       |
| 111 | 118 | Configurable | DMA2 channel3  | DMA2 channel3 global interrupt   | 0x0000_01FC       |
| 112 | 119 | Configurable | DMA2 channel4  | DMA2 channel4 global interrupt   | 0x0000_0200       |
| 113 | 120 | Configurable | DMA2 channel5  | DMA2 channel5 global interrupt   | 0x0000_0204       |
| 114 | 121 | Configurable | DMA2 channel6  | DMA2 channel6 global interrupt   | 0x0000_0208       |

Note: AT32F437 supports EMAC and EMAC\_WKUP interrupts, but AT32F435 does not.

### 1.1.5 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.6 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-6 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-7 Example of MSP and PC initialization



In the AT32F435/437 series, the main Flash memory, Boot code or SRAM can be remapped to the code area between 0x0000\_0000 and 0x07FF\_FFFF. BOOT1 and BOOT0 are used to set the specific memory from which CODE starts.

{BOOT1, BOOT0}=00/10, CODE starts from the main Flash memory

{BOOT1, BOOT0}=01, CODE starts from Boot code

{BOOT1, BOOT0}=11, CODE starts from SRAM

After a system reset or when leaving from Standby mode, the pin values of both BOOT1 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 code memory contains an embedded bootloader program that provides not only Flash programming function through USART1, USART2 or USB interface, but also provides extra firmware including communication protocol stacks that can be called for use by software developer 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 the bit. Reading it returns 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 List of abbreviations for 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: 0x0080 = 128 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 bit 31 to bit 0  |
| Bit 31: 0 | UID[63: 32] | 0xFFFF XXXX | ro   | UID for bit 63 to bit 32 |

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

Note: *UID[95:88]* is series ID, which is 0x0D for AT32F435, and 0x0E for AT32F437.

## 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 AT32F435/437 address mapping



### 2.2 Flash memory

AT32F435/437 series provide up to 4032 KB of on-chip Flash memory, supporting a 0-wait state single cycle 32-bit read operation.

Refer to [Chapter 5](#) for more details about Flash memory controller and register configuration.

#### Flash memory organization (4032K)

The main memory is divided into bank 1 and bank 2:

Bank 1: 2048 Kbytes, including 32 blocks, 16 sectors per block, and 4 Kbytes per sector.

Bank 2: 1984 Kbytes, including 31 blocks, 16 sectors per block, and 4 Kbytes per sector.  
User system data area is 4 Kbytes.

| Bank              | Name                  | Address range             |
|-------------------|-----------------------|---------------------------|
|                   | Sector 0              | 0x0800 0000 - 0x0800 0FFF |
|                   | Sector 1              | 0x0800 1000 - 0x0800 1FFF |
|                   | Sector 2              | 0x0800 2000 - 0x0800 2FFF |
|                   | ...                   | ...                       |
|                   | Sector 15             | 0x0800 F000 - 0x0800 FFFF |
|                   | Sector 16             | 0x0801 0000 - 0x0801 0FFF |
|                   | ...                   | ...                       |
|                   | Sector 31             | 0x0801 F000 - 0x0801 FFFF |
|                   | ...                   | ...                       |
| Main memory       | Sector 496            | 0x081F 0000 - 0x081F 0FFF |
|                   | ...                   | ...                       |
|                   | Sector 511            | 0x081F F000 - 0x081F FFFF |
|                   | Sector 512            | 0x0820 0000 - 0x0820 0FFF |
|                   | ...                   | ...                       |
|                   | Sector 527            | 0x0820 F000 - 0x0820 FFFF |
|                   | ...                   | ...                       |
|                   | Sector 992            | 0x083E 0000 - 0x083E 0FFF |
|                   | ...                   | ...                       |
|                   | Sector 1007           | 0x083E F000 - 0x083E FFFF |
| Information block | 16 KB bootloader      | 0x1FFF 0000 - 0x1FFF 3FFF |
|                   | 4 KB user system data | 0x1FFF C000 - 0x1FFF CFFF |

**Flash memory organization (1024K)**

The main memory features bank 1 and bank 2, with 512 Kbytes in each. Each bank is divided into 8 blocks, each of which includes 32 sectors and 2 Kbytes per sector.

User system data area is 512 bytes.

| Bank                  | Name                      | Address range             |                           |
|-----------------------|---------------------------|---------------------------|---------------------------|
| Main memory<br>512 KB | Block 0                   | Sector 0                  | 0x0800 0000 – 0x0800 07FF |
|                       |                           | Sector 1                  | 0x0800 0800 – 0x0800 0FFF |
|                       |                           | Sector 2                  | 0x0800 1000 – 0x0800 17FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 31                 | 0x0800 F800 - 0x0800 FFFF |
|                       | Block 1                   | Sector 32                 | 0x0801 0000 - 0x0801 07FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 63                 | 0x0801 F800 - 0x0801 FFFF |
|                       | Block 7                   | ...                       | ...                       |
|                       |                           | Sector 224                | 0x0807 0000 - 0x0807 07FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 255                | 0x0807 F800 – 0x0807 FFFF |
|                       | Block 8                   | Sector 256                | 0x0808 0000 – 0x0808 07FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 287                | 0x0808 F800 - 0x0808 FFFF |
|                       |                           | ...                       | ...                       |
| Information block     | Block 15                  | Sector 480                | 0x080F 0000 - 0x080F 07FF |
|                       |                           | ...                       | ...                       |
|                       | Block 15                  | Sector 511                | 0x080F F800 – 0x080F FFFF |
|                       |                           | 16 KB bootloader          | 0x1FFF 0000 - 0x1FFF 3FFF |
|                       | 512-byte user system data | 0x1FFF C000 - 0x1FFF C1FF |                           |

**Flash memory organization (448K)**

Main Flash memory (448 KB) has only bank 1, which is divided into 7 blocks that include 16 sectors in each, and 4 K per sector. User system data area is 4 KB.

| Bank                 | Name                 | Address range             |                           |
|----------------------|----------------------|---------------------------|---------------------------|
| Main memory<br>448KB | Block 0              | Sector 0                  | 0x0800 0000 - 0x0800 0FFF |
|                      |                      | Sector 1                  | 0x0800 1000 - 0x0800 1FFF |
|                      |                      | Sector 2                  | 0x0800 2000 - 0x0800 2FFF |
|                      |                      | ...                       | ...                       |
|                      |                      | Sector 15                 | 0x0800 F000 - 0x0800 FFFF |
|                      | Block 1              | Sector 16                 | 0x0801 0000 - 0x0801 0FFF |
|                      |                      | ...                       | ...                       |
|                      |                      | Sector 31                 | 0x0801 F000 - 0x0801 FFFF |
|                      |                      | ...                       | ...                       |
|                      | Block 6              | Sector 96                 | 0x0806 0000 - 0x0806 0FFF |
|                      |                      | ...                       | ...                       |
|                      |                      | Sector 111                | 0x0806 F000 - 0x0806 FFFF |
|                      |                      | 16 KB boot memory         | 0x1FFF 0000 - 0x1FFF 3FFF |
| Information block    | 4KB user system data | 0x1FFF C000 - 0x1FFF CFFF |                           |

### Flash memory organization (256K)

Main Flash memory (256 KB) has only bank 1, which is divided into 4 blocks that include 32 sectors in each, and 2 K per sector.

User system data area is 512 bytes.

| Bank                  | Name                      | Address range             |                           |
|-----------------------|---------------------------|---------------------------|---------------------------|
| Main memory<br>512 KB | Block 0                   | Sector 0                  | 0x0800 0000 – 0x0800 07FF |
|                       |                           | Sector 1                  | 0x0800 0800 – 0x0800 0FFF |
|                       |                           | Sector 2                  | 0x0800 1000 – 0x0800 17FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 31                 | 0x0800 F800 - 0x0800 FFFF |
|                       | Block 1                   | Sector 32                 | 0x0801 0000 - 0x0801 07FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 63                 | 0x0801 F800 - 0x0801 FFFF |
|                       | Block 2                   | Sector 64                 | 0x0802 0000 - 0x0802 07FF |
|                       |                           | ...                       | ...                       |
|                       |                           | Sector 95                 | 0x0802 F800 - 0x0802 FFFF |
|                       |                           | Sector 96                 | 0x0803 0000 - 0x0803 07FF |
|                       | Block 7                   | ...                       | ...                       |
|                       |                           | Sector 127                | 0x0803 F800 – 0x0803 FFFF |
| Information block     | 16 KB boot memory         | 0x1FFF 0000 - 0x1FFF 3FFF |                           |
|                       | 512-byte user system data | 0x1FFF C000 - 0x1FFF C1FF |                           |

## 2.3 SRAM memory

The AT32F435/437 series contain a 384-KB on-chip SRAM which starts at the address 0x2000\_0000. It can be accessed by bytes, half-words (16 bits) or words (32 bits). In addition, AT32F435/437 also provide a special mode that enables a dynamic switch between 128 KB (minimum) and 512 KB (maximum). This is done by setting the EOPB0 bit. In 512 KB mode, Flash memory size (zero wait state) is limited to 128 KB, while in 128 KB extension mode, the zero-wait-state Flash size is limited to 512 KB. On-chip SRAM is divided into SRAM1 and SRAM2. The SRAM1 is fixed at 64 KB, and can be accessed through either address 0x2000\_0000~0x2000\_FFFF or 0x1000\_0000~0x1000\_FFFF. The SRAM2 size ranges from 64 KB to 448 KB, accessible through address 0x2001\_0000~2007\_FFF.

## 2.4 Peripheral address map

Table 2-1 Peripheral boundary address

| Bus           | Boundary address          | Peripherals      |
|---------------|---------------------------|------------------|
| AHB BusMatrix | 0xC000 0000 - 0xDFFF FFFF | XMC_MEM(SDRAM)   |
|               | 0xB000 0000 - 0xBFFF FFFF | QSPI2_MEM        |
|               | 0xA800 0000 - 0xAF00 FFFF | XMC_MEM(PC CARD) |
|               | 0x9000 0000 - 0x9FFF FFFF | QSPI1_MEM        |
|               | 0x6000 0000 - 0x8FFF FFFF | XMC_MEM          |
|               | 0x5006 1000 - 0x5006 13FF | SDIO2            |
|               | 0x5005 0000 - 0x5005 03FF | DVP              |
|               | 0x5000 0000 - 0x5003 FFFF | OTG_FS1          |
|               | 0x4004 0000 - 0x4007 FFFF | OTG_FS2          |
|               | 0x4002 C400 - 0x4002 C7FF | SDIO1            |
|               | 0x4002 8000 - 0x4002 9FFF | EMAC             |
|               | 0x4002 1C00 - 0x4002 1FFF | GPIO port H      |

|      |                           |                                |
|------|---------------------------|--------------------------------|
|      | 0x4002 1800 - 0x4002 1BFF | GPIO port G                    |
|      | 0x4002 1400 - 0x4002 17FF | GPIO port F                    |
|      | 0x4002 1000 - 0x4002 13FF | GPIO port E                    |
|      | 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                    |
| AHB1 | 0xA000 2000 - 0xA000 2FFF | QSPI2_REG                      |
|      | 0xA000 1000 - 0xA000 1FFF | QSPI1_REG                      |
|      | 0xA000 0000 - 0xA000 0FFF | XMC_REG                        |
|      | 0x4002 6400 - 0x4002 67FF | DMA1_2                         |
|      | 0x4002 6000 - 0x4002 63FF | EDMA                           |
|      | 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                            |
|      | 0x4001 8000 - 0x4001 FFFF | Reserved                       |
|      | 0x4001 7C00 - 0x4001 7FFF | I2S3EXT                        |
| APB2 | 0x4001 7800 - 0x4001 7BFF | I2S2EXT                        |
|      | 0x4001 7400 - 0x4001 77FF | ACC                            |
|      | 0x4001 4C00 - 0x4001 73FF | TMR20 timer                    |
|      | 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 | SPI4/I2S4                      |
|      | 0x4001 3000 - 0x4001 33FF | SPI1/I2S1                      |
|      | 0x4001 2400 - 0x4001 2FFF | Reserved                       |
| APB1 | 0x4001 2000 - 0x4001 23FF | ADC1/2/3                       |
|      | 0x4001 1800 - 0x4001 1FFF | Reserved                       |
|      | 0x4001 1400 - 0x4001 17FF | USART6                         |
|      | 0x4001 1000 - 0x4001 13FF | USART1                         |
|      | 0x4001 0800 - 0x4001 0FFF | Reserved                       |
|      | 0x4001 0400 - 0x4001 07FF | TMR8 timer                     |
|      | 0x4001 0000 - 0x4001 03FF | TMR1 timer                     |
|      | 0x4000 8000 - 0x4000 FFFF | Reserved                       |
|      | 0x4000 7C00 - 0x4000 7FFF | UART8                          |
|      | 0x4000 7800 - 0x4000 7BFF | UART7                          |
|      | 0x4000 7400 - 0x4000 77FF | DAC                            |

|                           |                              |
|---------------------------|------------------------------|
| 0x4000 7000 - 0x4000 73FF | Power control (PWC)          |
| 0x4000 6C00 - 0x4000 6FFF | Reserved                     |
| 0x4000 6800 - 0x4000 6BFF | CAN2                         |
| 0x4000 6400 - 0x4000 67FF | CAN1                         |
| 0x4000 6000 - 0x4000 63FF | Reserved                     |
| 0x4000 5C00 - 0x4000 5FFF | I2C3                         |
| 0x4000 5800 - 0x4000 5BFF | I2C2                         |
| 0x4000 5400 - 0x4000 57FF | I2C1                         |
| 0x4000 5000 - 0x4000 53FF | UART5                        |
| 0x4000 4C00 - 0x4000 4FFF | UART4                        |
| 0x4000 4800 - 0x4000 4BFF | USART3                       |
| 0x4000 4400 - 0x4000 47FF | USART2                       |
| 0x4000 4000 - 0x4000 43FF | Reserved                     |
| 0x4000 3C00 - 0x4000 3FFF | SPI3/I2S3                    |
| 0x4000 3800 - 0x4000 3BFF | SPI2/I2S2                    |
| 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 | TMR12 timer                  |
| 0x4000 1400 - 0x4000 17FF | TMR7 timer                   |
| 0x4000 1000 - 0x4000 13FF | TMR6 timer                   |
| 0x4000 0C00 - 0x4000 0FFF | TMR5 timer                   |
| 0x4000 0800 - 0x4000 0BFF | TMR4 timer                   |
| 0x4000 0400 - 0x4000 07FF | TMR3 timer                   |
| 0x4000 0000 - 0x4000 03FF | TMR2 timer                   |

Note: Only AT32F437 supports EMAC module.

## 3 Power control (PWC)

### 3.1 Introduction

For AT32F435/437 series, its operating voltage supply is 2.6 V ~ 3.6 V, with a 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 AT32F435/437 series have three power domains — VDD/VDDA domain, 1.2 V domain and battery powered domain. The VDD/VDDA domain is supplied directly by external power, the 1.2 V domain is powered by an embedded LDO in the VDD/VDDA domain, and the battery powered domain is supplied through a  $V_{BAT}$  pin.

Figure 3-1 Block diagram of each power supply



### 3.2 Main Features

- Three power domains: VDD/VDDA domain, 1.2 V domain and battery powered 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 when the supply voltage is lower or higher than a programmed threshold
- The battery powered domain is powered by  $V_{BAT}$  when VDD is powered off
- 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 reset/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 the EXTI line 16 when VDD rises above the PVM threshold.

Figure 3-3 PVM threshold and output



### 3.5 Power domain

#### 1.2 V domain

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 and all PAD circuits other than PC13, PC14 and PC15. The VDDA domain contains DAC/ADC (DA/AD converters), temperature sensor and so on.

Typically, to ensure a better accuracy of ADC/DAC at a low voltage, the digital circuit is supplied by VDD while the analog circuit is powered by VDDA. On 64-pin packages and packages with less pins, the external reference voltage VREF+ and VREF- are connected to the 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 AT32F435/437 datasheets 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[2: 0])
- 3) Set the FLASH\_DIVR register and NZW\_BST bit in 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 when the PLL frequency is greater than 108 MHz
- 7) Switch the system clock to PLL

### Battery powered domain

The battery powered domain contains ERTC circuit, LEXT oscillator, PC13, PC14 and PC15, which is powered by either VDD or VBAT pin. When the VDD is cut off, the battery powered domain is automatically switched to VBAT pin to ensure that ERTC can work normally.

- 1) When the battery powered domain is powered by VDD, the PC13 can be used as a general-purpose I/O, tamper pin, ERTC calibration clock, ERTC alarm or second output, while the PC14 and PC15 can be used as a GPIO or LEXT pin. (As an I/O port, PC13, PC14 and PC15 must be limited below 2 MHz, and to the maximum load of 30 pF, and these I/O ports must not be used as current sources)
- 2) When the battery powered domain is powered by VBAT, the PC13 can be used as a tamper pin, ERTC alarm or second output, while the PC14 and PC15 can only be used as a LEXT pin.

The switch of the battery powered domain will not be disconnected from VBAT because of the VDD being at its rising phase or due to VDD low voltage reset. If the power switch has not been switched to the VDD when the VDD is powered on quickly, it is recommended to add a low voltage drop diode between VDD and VBAT in order to prevent the currents of VDD from being injected to VBAT. If there is no external battery in the application, it is better to connect the VBAT to a 100 nF ceramic filter capacitor that is externally connected to VDD.

## 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.

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 a 1.2 V power (for CPU core, memory and embedded peripherals) as it is in normal power consumption mode. The LDO output voltage is configurable by the PWC\_LDOOV register.

- 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 power control register before 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 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) When the Sleep mode is entered by executing a WFI instruction, the interrupt generated on any external interrupt line in Interrupt mode can wake up the system from Deepsleep mode.
- 2) When the Sleep mode is entered by executing a WFE instruction, the interrupt 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 as 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 limits)

- 1) Select HICK as system clock
- 2) Change LDO voltage to 1.0 V by setting the LDOOVSEL[2: 0] bit
- 3) Set the FLASH\_DIVR register and NZW\_BST bit in the FLASH\_PSR register
- 4) Set the VRSEL bit to enable low-power mode for the LDO
- 5) System enters Deepsleep state
- 6) System exits Deepsleep state (If wakeup conditions are met)
- 7) Change LDO voltage by setting the LDOOVSEL[2: 0]
- 8) If the HEXT is used as PLL clock, 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 when the PLL frequency is greater than 108 MHz
- 13) Switch the system clock to the 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 registers in the battery powered domain and standby circuitry remain

supplied.

The Standby mode is entered by the following procedures:

- Set the SLEEPDEE bit in the Cortex®-M4F system control register
- Set the LPSEL bit in the power control register (PWC\_CTRL)
- Clear the SWEF bit in the power control/status register (PWC\_CTRLSTS)
- Execute a WFI/WFE instruction

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

The MCU leaves the Standby mode when an external reset (NRST pin), a WDT reset, ERTC periodic wakeup, ERTC timestamp, ERTC tamper event, a rising edge on the WKUP pin or the rising edge of an ERTC alarm event 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 core is no longer clocked. However, the software can be debugged even in the low-power mode by setting some configuration bits in the DEBUG register (DEBUG\_CTRL).

## 3.7 PWC registers

The peripheral registers must be accessed by 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   | 0x000X 0X00 |

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

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                              |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 9 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                               |
| Bit 8     | BPWEN    | 0x0         | rw   | <p>Battery powered domain write enable<br/>0: Disabled<br/>1: Enabled<br/>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<br/>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<br/>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   | <p>Low power mode select when Cortex®-M4F sleepdeep<br/>0: Enter DEEPSLEEP mode<br/>1: Enter Standby mode</p>                                                                                                                                            |
| Bit 0     | VRSEL    | 0x0         | rw   | <p>LDO state select in Deepsleep mode<br/>0: Enabled<br/>1: Low-power consumption mode</p>                                                                                                                                                               |

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

Additional APB cycles are needed to read this register versus a standard APB read.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                          |
| Bit 9      | SWPEN2   | 0x0         | rw   | <p>Standby wake-up pin2 enable<br/>0: Disabled (this pin is used for general-purpose I/O)<br/>1: Enabled (this pin is forced in input pull-down mode, and no longer used for general-purpose I/O)<br/>Note: This bit is cleared by hardware after system reset.</p> |
| Bit 8      | SWPEN1   | 0x0         | rw   | <p>Standby wake-up pin1 enable<br/>0: Disabled (this pin is used for general-purpose I/O)<br/>1: Enabled (this pin is forced in input pull-down mode, and no longer used for general-purpose I/O)<br/>Note: This bit is cleared by hardware after system reset.</p> |
| Bit 7: 3   | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                          |
| Bit 2      | PVMOF    | 0x0         | ro   | <p>Power voltage monitoring output flag<br/>0: Power voltage is higher than the threshold<br/>1: Power voltage is lower than the threshold<br/>Note: The power voltage monitor is stopped in Standby mode.</p>                                                      |
| Bit 1      | SEF      | 0x0         | ro   | Standby mode entry flag<br>0: Device is not in Standby mode                                                                                                                                                                                                         |

|       |      |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |    | 1: Device is in Standby mode<br>Note: This bit is set by hardware (enter Standby mode) and cleared by POR/LVR or by setting the CLSEF bit.                                                                                                                                                                                                                                                                                                         |
|       |      |     |    | Standby wake-up event flag<br>0: No wakeup event occurred<br>1: A wakeup event occurred<br>Note:<br>This bit is set by hardware (on a wakeup event), and 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 RTC alarm event occurs;<br>If the Standby wakeup pin is enabled when the Standby wakeup pin level is high. |
| Bit 0 | SWEF | 0x0 | ro |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

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

| Bit       | Name     | Reset value | Type | Description                                                                                                                                             |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                              |
| Bit 2: 0  | LDOOVSEL | 0x0         | rw   | LDO output voltage select<br>000: 1.2V<br>001: 1.3V<br>010~011: Unused, not configurable<br>100: 1.1V<br>101: 1.0V<br>110~111: Unused, not configurable |

## 4 Clock and reset manage (CRM)

### 4.1 Clock

AT32F435/437 series provide different clock sources:

- HEXT (high speed external crystal)
- HICK (high speed internal clock)
- PLL (phased-locked loops)
- LEXT (low speed external crystal)
- LICK (low speed internal clock)

Figure 4-1 AT32F435/437 clock tree



AHB, APB1 and APB2 all support multiple frequency division. The AHB domain has a maximum of 288 MHz, and both APB1 and APB2 are up to 144 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 left floating.

- 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  $\pm 1\%$  accuracy ( $T_A=25^\circ C$ ) in factory. The factory calibration value is loaded in 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 using 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 1200 MHz. The PLL must be configured before enabling it. The reason is that the configuration parameters cannot be changed once PLL is enabled. The PLL clock signal is not released before 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 <= 1200 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 equals  $25 \times 192 / (5 \times 4) = 240$  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 32.768 KHz low-speed clock source. The LEXT clock signal is not released before it becomes stable.

- LEXT bypass clock

In this 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 while the LEXT\_OUT can 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 low-power 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 before 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 CPU FCLK(HCLK) or CPU systick(HCLK/8)

ADCs are clocked by APB2 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 PLL frequency divider. If the HICK is selected as a clock source, the USB clock should be set as 48 MHz; If the PLL frequency divider is selected as a clock source, the USB frequency divider provides 48 MHz USBCLK, and thus the PLL must be set as  $48 \times N \times 0.5$  MHz (N=2,3,4,5...)

ERTC clock sources: divided HEXT oscillator, LEXT oscillator and LICK oscillator. Once the clock source is selected, it cannot be altered without resetting the battery powered domain. 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 a system clock, directly or indirectly. If a failure is detected on the HEXT clock, a clock failure event is sent to the break input of TMR1 and TMR8 and an 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 clock is selected as the 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.

Note that when system clock source is switched to PLL (>108MHz), proceed as per the steps below:

- 1) Enable auto frequency swtich feature
- 2) Select PLL clock as system clock source
- 3) Insert 20 NOP commands
- 4) Check if the system clock source has switched to PLL clock
- 5) Disable auto frequency switch feature

#### 4.1.6 Clock output

The microcontroller allows the internal clock signal to be output to external CLKOUT1/2 pins. That is, ADCCLK, USB48M, SCLK, LICK, LEXT, HICK, HEXT, PLLCLK can be used as CLKOUT1/2 clocks. When being used as the CLKOUT1/2 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

AT32F435/437 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); this type of reset is also enabled when entering Deepsleep mode (by clearing the nDEPSLP\_RST 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 the battery powered domain; 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-2 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 or VBAT power on, if both supplies have been powered off.
- Software reset affects only the battery powered domain.

### 4.3 CRM registers

These peripheral registers have to be accessed by bytes (8 bits), half words (16 bits) or words (32 bits).

Table 4-1 CRM register map and reset values

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| CRM_CTRL     | 0x000  | 0x0000 XX83 |
| CRM_PLLCFG   | 0x004  | 0x0003 3002 |
| CRM_CFG      | 0x008  | 0x0000 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  | 0x3F63 90FF |

|              |       |             |
|--------------|-------|-------------|
| CRM_AHBLPEN2 | 0x054 | 0x0000 8081 |
| CRM_AHBLPEN3 | 0x058 | 0x0000 C003 |
| CRM_APB1LPEN | 0x060 | 0xF6FE E9FF |
| CRM_APB2LPEN | 0x064 | 0x2017 7733 |
| CRM_BPDC     | 0x070 | 0x0000 0000 |
| CRM_CTRLSTS  | 0x074 | 0x0C00 0000 |
| CRM_MISC1    | 0x0A0 | 0x0000 0000 |
| CRM_MISC2    | 0x0A4 | 0x0000 000D |

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

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 30: 26 | Reserved  | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 25     | PLLSTBL   | 0x0         | ro   | PLL clock stable<br>This bit is set by hardware after PLL is ready.<br>0: PLL clock is not ready.<br>1: PLL clock 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 the system clock, this bit cannot be cleared.<br>0: PLL is OFF<br>1: PLL is ON.                                                                                                                                                                                                                               |
| Bit 23: 20 | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 19     | CFDEN     | 0x0         | rw   | Clock failure detector enable<br>0: OFF<br>1: ON                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 18     | HEXTBYPSS | 0x0         | rw   | High speed external crystal bypass<br>This bit can be written only if the HEXT is disabled.<br>0: OFF<br>1: ON                                                                                                                                                                                                                                                                                                                                                                 |
| 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 the system clock, this bit cannot be cleared<br>0: OFF.<br>1: ON                                                                                                                                                                                                                     |
| 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 (design value), it needs adjust 40 kHz 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 the HICK is ready.<br>0: Not ready<br>1: Ready                                                                                                                                                                                                |
| Bit 0    | HICKEN   | 0x1  | rw | High speed internal clock enable<br>This bit is set and cleared by software. It can also be set by hardware when exiting Standby or Deepsleep mode. When a HEXT clock failure occurs. This bit can also be set. When the HICK is used as the 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: 23 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 22     | PLLRCSCS | 0x0         | rw   | PLL reference clock select<br>The PLL reference clock source is selected by setting or resetting this bit. 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 21: 19 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 18: 16 | PLL_FR   | 0x3         | rw   | PLL post-division<br>PLL_FR range (2~5)<br>000: Reserved. Do not use.<br>001: Reserved. Do not use.<br>010: PLL post-division=4<br>011: PLL post-division=8<br>100: PLL post-division=16<br>101: PLL post-division=32<br>Others: Reserved. Do not use.<br>Attention should be paid to the correlation between the PLL_FR value and post-division factor. |
| Bit 15     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 14: 6  | PLL_NS   | 0x0C0       | rw   | PLL multiplication factor<br>PLL_NS range (31~500)<br>00000000 ~ 000011110: Forbidden<br>000011111: 31<br>000100000: 32<br>000100001: 33<br>.....<br>111110011: 499<br>111110100: 500<br>111110101~111111111: Forbidden                                                                                                                                  |
| Bit 5: 4   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |

|          |        |     |    |                                                                                                                              |
|----------|--------|-----|----|------------------------------------------------------------------------------------------------------------------------------|
| Bit 3: 0 | PLL_MS | 0x2 | rw | PLL pre-division<br>PLL_MS range (1~15)<br>0000: Forbidden<br>0001: 1<br>0010: 2<br>0011: 3<br>.....<br>1110: 14<br>1111: 15 |
|----------|--------|-----|----|------------------------------------------------------------------------------------------------------------------------------|

Note: PLL clock formulas:

$\text{PLL output clock} = \text{PLL input clock} \times \text{PLL frequency multiplication factor} / (\text{PLL pre-divider factor} \times \text{PLL post-divider factor})$

$500 \text{ MHz} \leq \text{PLL input clock} \times \text{PLL frequency multiplication factor} / \text{PLL pre-divider factor} \leq 1200 \text{ MHz}$   
 $2 \text{ MHz} \leq \text{PLL input clock} / \text{PLL pre-divider factor} \leq 16 \text{ MHz}$

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

Access: 0 to 2 wait states. 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  | CLKOUT2_SEL1 | 0x0         | rw   | Clock output2 selection 1<br>This field is set and cleared by software.<br>00: System clock (SCLK) selected<br>01: Secondary clock output selected by the CLKOUT2_SEL2 bit in the CRM_MISC1 register<br>10: External oscillator clock (HEXT) selected<br>11: PLL clock output<br><br>Note: This clock out may be cut off during the startup and switch of CLKOUT2 clock source. While being used as an output to the CLKOUT2 pin, the system clock output frequency must be no more than 50 MHz (the maximum frequency of an IO port) |
| Bit 29: 27 | CLKOUT2DIV1  | 0x0         | rw   | Clock output2 division1<br>0xx: CLKOUT2<br>100: CLKOUT2/2<br>101: CLKOUT2/3<br>110: CLKOUT2/4<br>111: CLKOUT2/5                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 26: 24 | USBDIV       | 0x0         | rw   | Clock output1 division1<br>0xx: CLKOUT1<br>100: CLKOUT1/2<br>101: CLKOUT1/3<br>110: CLKOUT1/4<br>111: CLKOUT1/5                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 23     | Reserved     | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 22: 21 | CLKOUT1_SEL  | 0x0         | rw   | Clock output1 selection<br>This field is set and cleared by software.<br>00: HICK selected<br>01: LEXT selected<br>10: HEXT selected<br>11: PLL selected<br><br>Note: This clock out may be cut off during the startup and switch of CLKOUT1 clock source. While being used as an output to the CLKOUT1 pin, the system clock output frequency must not exceed 50 MHz (the maximum frequency of an IO port).                                                                                                                          |

|            |          |      |      |                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 20: 16 | ERTCDIV  | 0x00 | rw   | <p>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.</p> <p>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</p> |
| Bit 15: 13 | APB2DIV  | 0x0  | rw   | <p>APB2 division<br/>The divided HCLK is used as APB2 clock.</p> <p>0xx: not divided<br/>100: divided by 2<br/>101: divided by 4<br/>110: divided by 8<br/>111: divided by 16</p> <p>Note: The software must set these bits correctly to ensure that the APB2 clock frequency does not exceed 144 MHz.</p>                                      |
| Bit 12: 10 | APB1DIV  | 0x0  | rw   | <p>APB1 division<br/>The divided HCLK is used as APB1 clock.</p> <p>0xx: not divided<br/>100: divided by 2<br/>101: divided by 4<br/>110: divided by 8<br/>111: divided by 16</p> <p>Note: The software must set these bits correctly to ensure that the APB1 clock frequency does not exceed 144 MHz</p>                                       |
| Bit 9: 8   | Reserved | 0x0  | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                      |
| Bit 7: 4   | AHBDIV   | 0x0  | rw   | <p>AHB division<br/>0xxx: SCLK not divided<br/>1000: SCLK divided by 2    1100: SCLK divided by 64<br/>1001: SCLK divided by 4    1101: SCLK divided by 128<br/>1010: SCLK divided by 8    1110: SCLK divided by 256<br/>1011: SCLK divided by 16    1111: SCLK divided by 512</p>                                                              |
| Bit 3: 2   | SCLKSTS  | 0x0  | r0   | <p>System clock select status<br/>00: HICK<br/>01: HEXT<br/>10: PLL<br/>11: Reserved. Kept at its default value.</p>                                                                                                                                                                                                                            |
| Bit 1: 0   | SCLKSEL  | 0x0  | rw   | <p>System clock select<br/>00: HICK<br/>01: HEXT<br/>10: PLL<br/>11: Reserved. Kept at its default value.</p>                                                                                                                                                                                                                                   |

### 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 flag 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.<br>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<br>clock failure occurs.<br>0: No clock failure<br>1: Clock failure |
| Bit 6: 5   | Reserved    | 0x0         | resd | Keep at its default value.                                                                                                                    |

|       |           |     |    |                                                                                              |
|-------|-----------|-----|----|----------------------------------------------------------------------------------------------|
| Bit 4 | PLLSTBLF  | 0x0 | ro | PLL stable flag<br>Set by hardware.<br>0: PLL is not ready.<br>1: PLL is ready.              |
| Bit 3 | HEXTSTBLF | 0x0 | ro | HEXT stable flag<br>Set by hardware.<br>0: HEXT is not ready.<br>1: HEXT is ready.           |
| Bit 2 | HICKSTBLF | 0x0 | ro | HICK stable flag<br>Set by hardware.<br>0: HICK is not ready.<br>1: HICK is ready.           |
| Bit 1 | LEXTSTBLF | 0x0 | ro | LEXT stable flag<br>Set by hardware.<br>0: LEXT is not ready.<br>1: LEXT is ready.           |
| Bit 0 | LICKSTBLF | 0x0 | ro | LICK stable interrupt flag<br>Set by hardware.<br>0: LICK is not ready.<br>1: LICK is ready. |

### 4.3.5 APB peripheral reset register 1 (CRM\_APBRST1)

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     | OTGFS2RST | 0x0         | rw   | OTGFS2 reset<br>0: Does not reset the OTGFS2<br>1: Reset the OTGFS2           |
| Bit 28: 26 | Reserved  | 0x0         | resd | Kept at its default value.                                                    |
| Bit 25     | EMACRST   | 0x0         | rw   | EMAC reset<br>0: Does not reset the Ethernet MAC<br>1: Reset the Ethernet MAC |
| Bit 24     | DMA2RST   | 0x0         | rw   | DMA2 reset<br>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     | EDMARST   | 0x0         | rw   | EDMA reset<br>0: Does not reset EDMA<br>1: Reset EDMA                         |
| Bit 20: 13 | Reserved  | 0x0         | 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: 8  | Reserved  | 0x0         | resd | Kept at its default value.                                                    |
| Bit 7      | GPIOHRST  | 0x0         | rw   | IO port H reset<br>0: Does not reset IO port H<br>1: Reset IO port H          |
| Bit 6      | GPIOGRST  | 0x0         | rw   | IO port G reset<br>0: Does not reset IO port G<br>1: Reset IO port G          |
| 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 | GPIOERST | 0x0 | rw | IO port E reset<br>0: Does not reset IO port E<br>1: Reset IO port E |
| 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 APB peripheral reset register 2 (CRM\_APBRST2)

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

| Bit       | Name      | Reset value | Type | Description                                                 |
|-----------|-----------|-------------|------|-------------------------------------------------------------|
| Bit 31:16 | Reserved  | 0x0         | resd | Kept at its default value.                                  |
| Bit 15    | SDIO1RST  | 0x0         | rw   | SDIO1 reset<br>0: Does not reset SDIO1<br>1: Reset SDIO1    |
| Bit 14:8  | Reserved  | 0x0         | 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:1   | Reserved  | 0x0         | resd | Kept at its default value.                                  |
| Bit 0     | DVPRST    | 0x0         | rw   | DVP reset<br>0: Does not reset DVP<br>1: Reset DVP          |

#### 4.3.7 APB peripheral reset register 3 (CRM\_APBRST3)

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

| Bit       | Name     | Reset value | Type | Description                                              |
|-----------|----------|-------------|------|----------------------------------------------------------|
| Bit 31:16 | Reserved | 0x0         | resd | Kept at its default value.                               |
| Bit 15    | SDIO2RST | 0x0         | rw   | SDIO2 reset<br>0: Does not reset SDIO2<br>1: Reset SDIO2 |
| Bit 14    | QSPI2RST | 0x0         | rw   | QSPI2 reset<br>0: Does not reset QSPI2<br>1: Reset QSPI2 |
| Bit 13: 2 | Reserved | 0x0         | 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     | XMCRST   | 0x0         | rw   | XMC reset<br>0: Does not reset XMC<br>1: Reset XMC       |

### 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     | DACRST    | 0x0         | rw   | DAC interface reset<br>0: Does not reset DAC interface<br>1: Reset DAC interface             |
| Bit 28     | PWCRST    | 0x0         | rw   | Power interface reset<br>0: Does not reset Power interface<br>1: Reset Power interface       |
| Bit 27     | Reserved  | 0x0         | resd | Kept at its default value.                                                                   |
| Bit 26     | CAN2RST   | 0x0         | rw   | CAN2 reset<br>0: Does not reset CAN2<br>1: Reset CAN2                                        |
| 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     | UART5RST  | 0x0         | rw   | UART5 reset<br>0: Does not reset UART5<br>1: Reset UART5                                     |
| Bit 19     | UART4RST  | 0x0         | rw   | UART4 reset<br>0: Does not reset UART4<br>1: Reset UART4                                     |
| Bit 18     | USART3RST | 0x0         | rw   | USART3 reset<br>Set and cleared by software.<br>0: Does not reset USART3<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   | SPI3 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                                                   |

|       |          |     |    |                                               |
|-------|----------|-----|----|-----------------------------------------------|
|       |          |     |    | 1: Reset Timer13                              |
|       |          |     |    | Timer12 reset                                 |
| Bit 6 | TMR12RST | 0x0 | rw | 0: Does not reset Timer12<br>1: Reset Timer12 |
|       |          |     |    | Timer7 reset                                  |
| Bit 5 | TMR7RST  | 0x0 | rw | 0: Does not reset Timer7<br>1: Reset Timer7   |
|       |          |     |    | Timer6 reset                                  |
| Bit 4 | TMR6RST  | 0x0 | rw | 0: Does not reset Timer6<br>1: Reset Timer6   |
|       |          |     |    | Timer5 reset                                  |
| Bit 3 | TMR5RST  | 0x0 | rw | 0: Does not reset Timer5<br>1: Reset Timer5   |
|       |          |     |    | Timer4 reset                                  |
| Bit 2 | TMR4RST  | 0x0 | rw | 0: Does not reset Timer4<br>1: Reset Timer4   |
|       |          |     |    | Timer3 reset                                  |
| Bit 1 | TMR3RST  | 0x0 | rw | 0: Does not reset Timer3<br>1: Reset Timer3   |
|       |          |     |    | Timer2 reset                                  |
| Bit 0 | TMR2RST  | 0x0 | rw | 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.                                  |
|            |           |             |      | ACC reset                                                   |
| Bit 29     | ACCRST    | 0x0         | rw   | 0: Does not reset ACC<br>1: Reset ACC                       |
| Bit 28: 21 | Reserved  | 0x00        | resd | Kept at its default value.                                  |
|            |           |             |      | Timer20 reset                                               |
| Bit 20     | TMR20RST  | 0x0         | rw   | 0: Does not reset Timer20<br>1: Reset Timer20               |
| Bit 19     | Reserved  | 0x0         | resd | Kept at its default value.                                  |
|            |           |             |      | Timer11 reset                                               |
| Bit 18     | TMR11RST  | 0x0         | rw   | 0: Does not reset Timer11<br>1: Reset Timer11               |
|            |           |             |      | Timer10 reset                                               |
| Bit 17     | TMR10RST  | 0x0         | rw   | 0: Does not reset Timer10<br>1: Reset Timer10               |
|            |           |             |      | Timer9 reset                                                |
| Bit 16     | TMR9RST   | 0x0         | rw   | 0: Does not reset Timer9<br>1: Reset Timer9                 |
| Bit 15     | Reserved  | 0x0         | resd | Kept at its default value.                                  |
|            |           |             |      | SCFG reset                                                  |
| Bit 14     | SCFGRST   | 0x0         | rw   | 0: Does not reset SCFG<br>1: Reset SCFG                     |
|            |           |             |      | SPI4 reset                                                  |
| Bit 13     | SPI4RST   | 0x0         | rw   | 0: Does not reset SPI4<br>1: Reset SPI4                     |
|            |           |             |      | SPI1 reset                                                  |
| Bit 12     | SPI1RST   | 0x0         | rw   | 0: Does not reset SPI1<br>1: Reset SPI1                     |
| Bit 11: 9  | Reserved  | 0x0         | resd | Kept at its default value.                                  |
|            |           |             |      | ADC interface reset                                         |
| Bit 8      | ADCRST    | 0x0         | rw   | 0: Does not reset ADC1 interface<br>1: Reset ADC1 interface |
| Bit 7: 6   | Reserved  | 0x0         | resd | Kept at its default value.                                  |
|            |           |             |      | USART6 reset                                                |
| Bit 5      | USART6RST | 0x0         | rw   | 0: Does not reset USART6<br>1: Reset USART6                 |
| Bit 4      | USART1RST | 0x0         | rw   | USART1 reset                                                |

|          |          |     |      |                                                             |
|----------|----------|-----|------|-------------------------------------------------------------|
|          |          |     |      | 0: Does not reset USART1<br>1: Reset USART1                 |
| Bit 3: 2 | Reserved | 0x0 | resd | Kept at its default value.                                  |
| Bit 1    | TMR8RST  | 0x0 | rw   | TMR8 timer reset<br>0: Does not reset TMR8<br>1: Reset TMR8 |
| Bit 0    | TMR1RST  | 0x0 | rw   | TMR1 timer reset<br>0: Does not reset TMR1<br>1: Reset TMR1 |

#### 4.3.10 APB 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     | OTGFS2EN  | 0x0         | rw   | OTGFS2 clock enable<br>0: Disabled<br>1: Enabled                                                                                           |
| Bit 28     | EMACPTPEN | 0x0         | rw   | EMAC PTP clock enable<br>0: Disabled<br>1: Enabled                                                                                         |
| Bit 27     | EMACRXEN  | 0x0         | rw   | EMAC RX clock enable<br>0: Disabled<br>1: Enabled<br>Note: In RMII mode, if this clock is enabled, then MAC RMII clock is enabled as well. |
| Bit 26     | EMACTXEN  | 0x0         | rw   | EMAC TX clock enable<br>0: Disabled<br>1: Enabled<br>Note: In RMII mode, if this clock is enabled, then MAC RMII clock is enabled as well. |
| Bit 25     | EMACEN    | 0x0         | rw   | EMAC clock enable<br>0: Disabled<br>1: Enabled                                                                                             |
| 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     | EDMAEN    | 0x0         | rw   | EDMA clock enable<br>0: Disabled<br>1: Enabled                                                                                             |
| Bit 20:13  | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                 |
| Bit 12     | CRCEN     | 0x0         | rw   | CRC clock enable<br>0: Disabled<br>1: Enabled                                                                                              |
| Bit 11: 8  | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                 |
| Bit 7      | GPIOHEN   | 0x0         | rw   | IO port H clock enable<br>0: Disabled<br>1: Enabled                                                                                        |
| Bit 6      | GPIOGEN   | 0x0         | rw   | IO port G clock enable<br>0: Disabled<br>1: Enabled                                                                                        |

|       |         |     |    |                                                     |
|-------|---------|-----|----|-----------------------------------------------------|
| Bit 5 | GPIOFEN | 0x0 | rw | IO port F clock enable<br>0: Disabled<br>1: Enabled |
| Bit 4 | GPIOEEN | 0x0 | rw | IO port E clock enable<br>0: Disabled<br>1: Enabled |
| 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 APB 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: 16 | Reserved | 0x00        | resd | Kept at its default value.                       |
| Bit 15     | SDIO1EN  | 0x0         | rw   | SDIO1 clock enable<br>0: Disabled<br>1: Enabled  |
| Bit 14: 8  | Reserved | 0x0         | resd | Kept at its default value.                       |
| Bit 7      | OTGFS1EN | 0x0         | rw   | OTGFS1 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 6:1    | Reserved | 0x0         | resd | Kept at its default value.                       |
| Bit 0      | DVPEN    | 0x0         | rw   | DVP clock enable<br>0: Disabled<br>1: Enabled    |

#### 4.3.12 APB1 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: 16 | Reserved | 0x00        | resd | Kept at its default value.                      |
| Bit 15     | SDIO2EN  | 0x0         | rw   | SDIO2 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 14     | QSPI2EN  | 0x0         | rw   | QSPI2 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 13: 2  | Reserved | 0x0         | resd | Kept at its default value.                      |
| Bit 1      | QSPI1EN  | 0x0         | rw   | QSPI1 clock enable<br>0: Disabled<br>1: Enabled |
| Bit 0      | XMCEN    | 0x0         | rw   | XMC clock enable<br>0: Disabled<br>1: Enabled   |

### 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     | DACEN    | 0x0         | rw   | DAC interface clock enable<br>0: Disabled<br>1: Enabled     |
| Bit 28     | PWCEN    | 0x0         | rw   | Power interface clock enable<br>0: Disabled<br>1: Enabled   |
| Bit 27     | Reserved | 0x0         | resd | Kept at its default value.                                  |
| Bit 26     | CAC2EN   | 0x0         | rw   | CAN2 clock enable<br>0: Disabled<br>1: Enabled              |
| Bit 25     | CAC1EN   | 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     | UART5EN  | 0x0         | rw   | UART5 clock enable<br>0: Disabled<br>1: Enabled             |
| Bit 19     | UART4EN  | 0x0         | rw   | UART4 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         | rw   | 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 | rw | 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     | TMR12EN  | 0x0 | rw | Timer12 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 5     | TMR7EN   | 0x0 | rw | Timer7 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 4     | TMR6EN   | 0x0 | rw | Timer6 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 3     | TMR5EN   | 0x0 | rw | Timer5 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 2     | TMR4EN   | 0x0 | rw | Timer4 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 1     | TMR3EN   | 0x0 | rw | Timer3 clock enable<br>0: Disabled<br>1: Enabled          |
| Bit 0     | TMR2EN   | 0x0 | rw | Timer2 clock enable<br>0: Disabled<br>1: Enabled          |

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

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     | ACCEN    | 0x0         | rw   | ACC clock enable<br>0: Disabled<br>1: Enabled     |
| Bit 28: 21 | Reserved | 0x0         | resd | Kept at its default value.                        |
| Bit 20     | TMR20EN  | 0x0         | rw   | Timer20 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<br>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   | SPI4EN   | 0x0 | rw   | SPI4 clock enable<br>0: Disabled<br>1: Enabled           |
| Bit 12   | SPI1EN   | 0x0 | rw   | SPI1 clock enable<br>0: Disabled<br>1: Enabled           |
| Bit 11   | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 10   | ADC3EN   | 0x0 | rw   | ADC3 interface clock enable<br>0: Disabled<br>1: Enabled |
| Bit 9    | ADC2EN   | 0x0 | rw   | ADC2 interface clock enable<br>0: Disabled<br>1: Enabled |
| Bit 8    | ADC1EN   | 0x0 | rw   | ADC1 interface clock enable<br>0: Disabled<br>1: Enabled |
| Bit 7: 6 | Reserved | 0x0 | rw   | 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: 2 | Reserved | 0x0 | resd | Kept at its default value.                               |
| Bit 1    | TMR8EN   | 0x0 | rw   | Timer8 clock enable<br>0: Disabled<br>1: Enabled         |
| Bit 0    | TMR1EN   | 0x0 | rw   | Timer1 clock enable<br>0: Disabled<br>1: Enabled         |

### 4.3.15 APB peripheral clock enable in low power mode register1 (CRM\_AHBLPEN1)

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     | OTGFS2LPEN  | 0x1         | rw   | OTGFS2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled                                                                                               |
| Bit 28     | EMACPTPLPEN | 0x1         | rw   | EMAC PTP clock enable in sleep mode<br>0: Disabled<br>1: Enabled                                                                                             |
| Bit 27     | EMACRXLPEN  | 0x1         | rw   | EMAC RX clock enable in sleep mode<br>0: Disabled<br>1: Enabled<br>Note: In RMII mode, if this clock is enabled, then the MAC RMII clock is enabled as well. |
| Bit 26     | EMACTXLPEN  | 0x1         | rw   | EMAC TX clock enable in sleep mode<br>Set and cleared by software.<br>0: Disabled<br>1: Enabled                                                              |

|            |           |     |      |                                                                                           |
|------------|-----------|-----|------|-------------------------------------------------------------------------------------------|
|            |           |     |      | Note: In RMII mode, if this clock is enabled, then the MAC RMII clock is enabled as well. |
| Bit25      | EMACLPEN  | 0x1 | rw   | EMAC clock enable during sleep mode<br>0: Disabled<br>1: Enabled                          |
| 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     | EDMALPEN  | 0x1 | rw   | EDMA clock enable in sleep mode<br>0: Disabled<br>1: Enabled                              |
| Bit 20: 18 | Reserved  | 0x0 | resd | Kept at its default value.                                                                |
| Bit 17     | SRAM2LPEN | 0x1 | rw   | SRAM2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled                             |
| Bit 16     | SRAM1LPEN | 0x1 | rw   | SRAM1 clock enable in sleep mode<br>0: Disabled<br>1: Enabled                             |
| Bit 15     | FLASHLPEN | 0x1 | rw   | FLASH clock enable during sleep mode<br>0: Disabled<br>1: Enabled                         |
| Bit 14: 13 | Reserved  | 0x0 | resd | Kept at its default value.                                                                |
| Bit12      | CRCLPEN   | 0x1 | rw   | CRC clock enable during sleep mode<br>0: Disabled<br>1: Enabled                           |
| Bit 11: 8  | Reserved  | 0x0 | resd | Kept at its default value.                                                                |
| Bit 7      | GPIOHLPEN | 0x1 | rw   | IO port H clock enable in sleep mode<br>0: Disabled<br>1: Enabled                         |
| Bit 6      | GPIOGLPEN | 0x1 | rw   | IO port G clock enable in sleep mode<br>0: Disabled<br>1: Enabled                         |
| Bit 5      | GPIOFLPEN | 0x1 | rw   | IO port F clock enable in sleep mode<br>0: Disabled<br>1: Enabled                         |
| Bit 4      | GPIOELPEN | 0x1 | rw   | IO port E clock enable in sleep mode<br>0: Disabled<br>1: Enabled                         |
| 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<br>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 APB peripheral clock enable in low power mode register2 (CRM\_AHBLPEN2)

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

| Bit        | Name       | Reset value | Type | Description                                                    |
|------------|------------|-------------|------|----------------------------------------------------------------|
| Bit 31: 16 | Reserved   | 0x0000      | resd | Kept at its default value.                                     |
| Bit 15     | SDIO1LPEN  | 0x1         | rw   | SDIO1 clock enable in sleep mode<br>0: Disabled<br>1: Enabled  |
| Bit 14: 8  | Reserved   | 0x00        | 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: 1   | Reserved   | 0x00        | resd | Kept at its default value.                                     |
| Bit 0      | DVPLPEN    | 0x1         | rw   | DVP clock enable in sleep mode<br>0: Disabled<br>1: Enabled    |

### 4.3.17 APB peripheral clock enable in low power mode register3 (CRM\_AHBLPEN3)

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

| Bit        | Name      | Reset value | Type | Description                                                   |
|------------|-----------|-------------|------|---------------------------------------------------------------|
| Bit 31: 16 | Reserved  | 0x0000      | resd | Kept at its default value.                                    |
| Bit 15     | SDIO2LPEN | 0x0         | rw   | SDIO2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 14     | QSPI2LPEN | 0x0         | rw   | QSPI2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 13: 2  | Reserved  | 0x000       | 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      | XMC LPEN  | 0x1         | rw   | XMC clock enable in sleep mode<br>0: Disabled<br>1: Enabled   |

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

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 | DACL PEN  | 0x1         | rw   | DAC interface clock enable in sleep mode<br>0: Disabled<br>1: Enabled   |
| Bit 28 | PWCLPEN   | 0x1         | rw   | Power interface clock enable in sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 27 | Reserved  | 0x0         | resd | Kept at its default value.                                              |
| Bit 26 | CAN2LPEN  | 0x1         | rw   | CAN2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled            |
| 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   | I2C3 clock enable in sleep mode<br>0: Disabled<br>1: Enabled            |
| Bit 22     | I2C2LPEN   | 0x1 | rw   | I2C2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled            |
| Bit 21     | I2C1LPEN   | 0x1 | rw   | I2C1 clock enable in sleep mode<br>0: Disabled<br>1: Enabled            |
| Bit 20     | UART5LPEN  | 0x1 | rw   | UART5 clock enable in sleep mode<br>0: Disabled<br>1: Enabled           |
| Bit 19     | UART4LPEN  | 0x1 | rw   | UART4 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   | SPI 2 clock enable in sleep mode<br>0: Disabled<br>1: Enabled           |
| Bit 13: 12 | Reserved   | 0x2 | 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      | TMR12LPEN  | 0x1 | rw   | Timer12 clock enable in sleep mode<br>0: Disabled<br>1: Enabled         |
| 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      | TMR5LPEN   | 0x1 | rw   | Timer 5 clock enable in sleep mode<br>0: Disabled<br>1: Enabled         |
| 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\_AHB2LPEN)

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     | 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     | TMR20LPEN  | 0x1         | rw   | Timer20 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 during 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     | SPI4LPEN   | 0x1         | rw   | SPI4 clock enable in sleep mode<br>0: Disabled<br>1: Enabled           |
| Bit 12     | SPI1LPEN   | 0x1         | rw   | SPI1 clock enable in sleep mode<br>0: Disabled<br>1: Enabled           |
| Bit 11     | Reserved   | 0x0         | resd | Kept at its default value.                                             |
| Bit 10     | ADC3LPEN   | 0x1         | rw   | ADC3 interface clock enable in sleep mode<br>0: Disabled<br>1: Enabled |
| Bit 9      | ADC2LPEN   | 0x1         | rw   | ADC2 interface clock enable in sleep mode<br>0: Disabled<br>1: Enabled |
| 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: 2   | Reserved   | 0x0         | resd | Kept at its default value.                                             |
| Bit 1      | TMR8LPEN   | 0x1         | rw   | TMR8 timer clock enable in sleep mode<br>0: Disabled<br>1: Enabled     |
| 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)

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

*Note: LEXTEN, LEXTBYP, ERTCSEL, and ERTCEN bits of the battery powered domain control register CRM\_BDC) 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 power control register (PWR\_CTRL). These bits could be reset only by battery powered domain reset. Any internal or external reset does not affect these bits.*

| 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: Do not reset battery powered domain software<br>1: Reset battery powered domain software                                                                                   |
| Bit 15     | ERTCEN   | 0x0         | rw   | ERTC clock enable<br>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 selection<br>Once the ERTC clock source is selected, it cannot be changed until the BPDRST bit is reset.<br>00: No clock<br>01: LEXT<br>10: LICK<br>11: Divided HEXT (with the ERTC_DIV bit in the CRM_CFG) |
| Bit 7: 3   | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                             |
| Bit 2      | LEXTBYP  | 0x0         | rw   | Low speed external crystal bypass<br>0: Disabled<br>1: Enabled                                                                                                                                                         |
| Bit 1      | LEXTSTBL | 0x0         | ro   | Low speed external oscillator stable<br>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 only 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 or bytes. Wait states are inserted in the case of consecutive accesses to this register.

| Bit    | Name     | Reset value | Type | Description                                                                                                                                                                    |
|--------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31 | LPRSTF   | 0x0         | ro   | Low-power reset flag<br>Set by hardware. Cleared by writing to the RSTFC bit.<br>0: No low-power reset occurs<br>1: Low-power reset occurs                                     |
| Bit 30 | WWDTRSTF | 0x0         | ro   | Window watchdog timer reset flag<br>Set by hardware. Cleared by writing to the RSTFC bit.<br>0: No window watchdog timer reset occurs<br>1: Window watchdog timer reset occurs |

|           |          |          |      |                                                                                                                                                            |
|-----------|----------|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 29    | WDTRSTF  | 0x0      | ro   | Watchdog timer reset flag<br>Set by hardware. Cleared by writing to the RSTFC bit.<br>0: No watchdog timer reset occurs<br>1: Watchdog timer reset occurs. |
| Bit 28    | SWRSTF   | 0x0      | ro   | Software reset flag<br>Set by hardware. Cleared by writing to the RSTFC bit.<br>0: No software reset occurs<br>1: Software reset occurs.                   |
| Bit 27    | PORRSTF  | 0x1      | ro   | POR/LVR reset flag<br>Set by hardware. Cleared by writing to the RSTFC bit.<br>0: No POR/LVR reset occurs<br>1: POR/LVR reset occurs.                      |
| Bit 26    | NRSTF    | 0x1      | rw   | NRST pin reset flag<br>Set by hardware. Cleared by writing to the RSTFC bit.<br>0: No NRST pin reset occurs<br>1: NRST pin reset occurs                    |
| Bit 25    | Reserved | 0x0      | resd | Kept at its default value.                                                                                                                                 |
| Bit 24    | RSTFC    | 0x0      | rw   | Reset flag clear<br>Cleared by writing 1 through software.<br>0: No effect<br>1: Clear the 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 Additional register 1 (CRM\_MISC1)

Access: 0 to 3 wait states, accessible by words, half-words or bytes.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 28 | CLKOUT2DIV2 | 0x0         | rw   | Clock output2 division2<br>0xxx: Clock output<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: 24 | CLKOUT1DIV2 | 0x0         | rw   | Clock output1 division2<br>0xxx: Clock output<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 23: 20 | Reserved     | 0x0  | resd | Kept its default value.                                                                                                                                                                                                                                                                        |
|            |              |      |      | Clock output2 sel2<br>0000: USB clock output<br>0001: ADC clock output                                                                                                                                                                                                                         |
| Bit 19: 16 | CLKOUT2_SEL2 | 0x0  | rw   | 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 its default value.                                                                                                                                                                                                                                                                        |
| Bit 14     | HICK_TO_SCLK | 0x0  | rw   | HICK as system clock frequency select<br>When the HICK is selected as the clock source of SCLKSEL, 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     | HICK_TO_USB  | 0x0  | rw   | USB 48 MHz clock source select<br>0: PLL or PLL division<br>1: HICK or HICK/6<br>Note: Since USB must work at 48 MHz, HICKDIV=1 must be guaranteed to ensure that the HICK 48 MHz is selected as the clock source of USB 48 MHz.                                                               |
| 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 clock frequency is 8 MHz. Otherwise, the clock frequency is 48 MHz.<br>0: HICK/6<br>1: HICK<br>Note: When HICK is used as PLL clock source, do not modify HICKDIV while PLL is enabled. |
| Bit 11: 8  | Reserved     | 0x00 | 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 0x5A.                                                                                                                                                                                                     |

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

| Bit        | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|--------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved     | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 15: 12 | USBDIV       | 0x0         | rw   | USB division<br>The PLL clock frequency, after being divided, is used as USB clock.<br>0000: PLL clock divided by 1.5<br>0001: PLL clock not divided<br>0010: PLL clock divided by 2.5<br>0011: PLL clock divided by 2<br>0100: PLL clock divided by 3.5<br>0101: PLL clock divided by 3<br>0110: PLL clock divided by 4.5<br>0111: PLL clock divided by 4<br>1000: PLL clock divided by 5.5<br>1001: PLL clock divided by 5<br>1010: PLL clock divided by 6.5<br>1011: PLL clock divided by 6<br>1100: PLL clock divided by 7<br>1101~1111: Reserved |
| Bit 11: 10 | Reserved     | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 9      | EMAC_PPS_SEL | 0x0         | rw   | Ethernet pulse width select<br>0: Pulse width is 125 ms.<br>1: Pulse width is 1 system clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 8      | CLK1_TO_TMR  | 0x0         | rw   | CLKOUT1 internal connected to timer 10 channel 1<br>0: Disconnected<br>1: Connected                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 7: 6   | Reserved     | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 5: 4   | AUTO_STEP_EN | 0x0         | rw   | Auto step-by-step system clock switch enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

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.

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.

00: Disabled

01: Reserved

10: Reserved

11: Enabled. When AHBDIV or SCLKSEL is modified, the auto step-by-step system clock switch is activated automatically.

|          |          |     |      |                                    |
|----------|----------|-----|------|------------------------------------|
| 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 4032 KB, including bank 1 and bank 2.
- Information block consists of 16 KB bootloader and the user system data area. The bootloader uses USART1, USART2 or USB (DFU) serial interface for ISP programming.

Main Flash memory (4032 KB) is divided into bank 1 and bank 2.

Bank 1: 2048 KB, including 32 blocks with 16 sectors in each, and 4 KB per sector.

Bank 2: 1984 KB, including 31 blocks with 16 sectors in each, and 4 KB per sector.

User system data area is 4 KB.

Table 5-1 Flash memory architecture (4032 K)

| Bank              | Name              | Address range         |                           |
|-------------------|-------------------|-----------------------|---------------------------|
| Main Flash memory | Bank 1<br>2048 KB | Sector 0              | 0x0800 0000 - 0x0800 0FFF |
|                   |                   | Sector 1              | 0x0800 1000 - 0x0800 1FFF |
|                   |                   | Sector 2              | 0x0800 2000 - 0x0800 2FFF |
|                   |                   | ...                   | ...                       |
|                   |                   | Sector 15             | 0x0800 F000 - 0x0800 FFFF |
|                   |                   | Sector 16             | 0x0801 0000 - 0x0801 0FFF |
|                   |                   | ...                   | ...                       |
|                   |                   | Sector 31             | 0x0801 F000 - 0x0801 FFFF |
|                   |                   | ...                   | ...                       |
|                   |                   | Sector 496            | 0x081F 0000 - 0x081F 0FFF |
|                   |                   | ...                   | ...                       |
|                   |                   | Sector 511            | 0x081F F000 - 0x081F FFFF |
|                   |                   | Sector 512            | 0x0820 0000 - 0x0820 0FFF |
|                   |                   | ...                   | ...                       |
|                   |                   | Sector 527            | 0x0820 F000 - 0x0820 FFFF |
|                   |                   | ...                   | ...                       |
| Information block | Bank 2<br>1984 KB | Sector 992            | 0x083E 0000 - 0x083E 0FFF |
|                   |                   | ...                   | ...                       |
|                   |                   | Sector 1007           | 0x083E F000 - 0x083E FFFF |
|                   |                   | 16 KB boot memory     | 0x1FFF 0000 - 0x1FFF 3FFF |
|                   |                   | 4 KB user system area | 0x1FFF C000 - 0x1FFF CFFF |

Main Flash memory (1024 KB) is divided into bank 1 and bank 2 with 512 KB in each. Each bank is subdivided into 8 blocks that include 32 sectors in each, and 2 KB per sector.

User system data area is 512 B.

Table 5-2 Flash memory architecture (1024 K)

| Bank              | Name                   | Address range             |                           |
|-------------------|------------------------|---------------------------|---------------------------|
| Main Flash memory | Bank 1<br>512 KB       | Sector 0                  | 0x0800 0000 – 0x0800 07FF |
|                   |                        | Sector 1                  | 0x0800 0800 – 0x0800 0FFF |
|                   |                        | Sector 2                  | 0x0800 1000 – 0x0800 17FF |
|                   |                        | ...                       | ...                       |
|                   |                        | Sector 31                 | 0x0800 F800 - 0x0800 FFFF |
|                   | Block 1                | Sector 32                 | 0x0801 0000 - 0x0801 07FF |
|                   |                        | ...                       | ...                       |
|                   |                        | Sector 63                 | 0x0801 F800 - 0x0801 FFFF |
|                   | Bank 2<br>512 KB       | ...                       | ...                       |
|                   |                        | Sector 224                | 0x0807 0000 - 0x0807 07FF |
|                   |                        | ...                       | ...                       |
|                   |                        | Sector 255                | 0x0807 F800 – 0x0807 FFFF |
|                   |                        | Sector 256                | 0x0808 0000 – 0x0808 07FF |
|                   |                        | ...                       | ...                       |
|                   |                        | Sector 287                | 0x0808 F800 - 0x0808 FFFF |
|                   |                        | ...                       | ...                       |
| Information block | 16 KB boot memory      | Sector 480                | 0x080F 0000 - 0x080F 07FF |
|                   |                        | ...                       | ...                       |
|                   | Sector 511             | 0x080F F800 – 0x080F FFFF |                           |
| Information block | 512 B user system area | 0x1FFF C000 - 0x1FFF C1FF |                           |

Main Flash memory (448 KB) has only bank 1, which is divided into 7 blocks that include 16 sectors in each, and 4 K per sector.

User system data area is 4 KB.

Table 5-3 Flash memory architecture (448 K)

| Bank              | Name            | Address range         |                           |
|-------------------|-----------------|-----------------------|---------------------------|
| Main Flash memory | Bank1<br>448 KB | Sector 0              | 0x0800 0000 - 0x0800 0FFF |
|                   |                 | Sector 1              | 0x0800 1000 - 0x0800 1FFF |
|                   |                 | Sector 2              | 0x0800 2000 - 0x0800 2FFF |
|                   |                 | ...                   | ...                       |
|                   |                 | Sector 15             | 0x0800 F000 - 0x0800 FFFF |
|                   |                 | Sector 16             | 0x0801 0000 - 0x0801 0FFF |
|                   |                 | ...                   | ...                       |
|                   |                 | Sector 31             | 0x0801 F000 - 0x0801 FFFF |
|                   | Block 6         | ...                   | ...                       |
|                   |                 | Sector 96             | 0x0806 0000 - 0x0806 0FFF |
|                   |                 | ...                   | ...                       |
|                   |                 | Sector 111            | 0x0806 F000 - 0x0806 FFFF |
|                   |                 | 16 KB boot memory     | 0x1FFF 0000 - 0x1FFF 3FFF |
|                   |                 | 4 KB user system area | 0x1FFF C000 - 0x1FFF CFFF |

Main Flash memory (256 KB) has only bank 1, which is divided into 4 blocks that include 32 sectors in each, and 2 K per sector.

User system data area is 512 B.

Table 5-4 Flash memory architecture (256 K)

| Bank                           | Name                   | Address range                           |
|--------------------------------|------------------------|-----------------------------------------|
| Main<br>Flash memory<br>256 KB | Block 0                | Sector 0<br>0x0800 0000 – 0x0800 07FF   |
|                                |                        | Sector 1<br>0x0800 0800 – 0x0800 0FFF   |
|                                |                        | Sector 2<br>0x0800 1000 – 0x0800 17FF   |
|                                |                        | ...                                     |
|                                |                        | Sector 31<br>0x0800 F800 - 0x0800 FFFF  |
|                                |                        | Sector 32<br>0x0801 0000 - 0x0801 07FF  |
|                                |                        | ...                                     |
|                                |                        | Sector 63<br>0x0801 F800 - 0x0801 FFFF  |
|                                | Block 2                | Sector 64<br>0x0802 0000 - 0x0802 07FF  |
|                                |                        | ...                                     |
|                                |                        | Sector 95<br>0x0802 F800 - 0x0802 FFFF  |
|                                |                        | Sector 96<br>0x0803 0000 - 0x0803 07FF  |
|                                | Block 3                | ...                                     |
|                                |                        | Sector 127<br>0x0803 F800 – 0x0803 FFFF |
| Information block              | 16 KB boot memory      | 0x1FFF 0000 - 0x1FFF 3FFF               |
|                                | 512 B user system data | 0x1FFF C000 - 0x1FFF C1FF               |

### 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-5 User system data area

| Address     | Bit      | Description                                                                                                                                                                                                                                                     |
|-------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x1FFF_C000 | [7: 0]   | FAP[7:0]: Flash memory access protection (Access protection enable/disable result is stored in the FLASH_USD[1] register )<br>0xA5: Disabled<br>0xFF: Enable Flash access protection (by erasing USD area. At this point, nFAP remains 0xFF)<br>Others: Enabled |
|             |          | [15: 8]<br>nFAP[7: 0]: Inverse code of FAP[7: 0]                                                                                                                                                                                                                |
|             | [23: 16] | SSB[7:0]: System configuration byte (it is stored in the FLASH_USD[9: 2] register)<br>Bit 7<br>0: WDT stops counting while entering Standby mode<br>1: WDT does not stop counting while entering Standby mode                                                   |
|             |          | Bit 6 (nSTDBY_WDT)<br>0: WDT stops counting while entering Deepsleep mode<br>1: WDT does not stop counting while entering Deepsleep mode                                                                                                                        |
|             |          | Bit 5 (nDEPSLP_WDT)<br>0: When booting from main Flash memory, if there is no bootloader in the bank 2, it will starts from bank 1; otherwise, bank 2.<br>1: When booting from main Flash memory, it starts from bank 1.                                        |
|             |          | Bit 4<br>Reserved                                                                                                                                                                                                                                               |
|             |          | Bit 3 (BTOPT)<br>0: Reset occurs when entering Standby mode<br>1: No reset occurs when entering                                                                                                                                                                 |
|             |          | Bit 2 (nSTDBY_RST)                                                                                                                                                                                                                                              |

|             |          |                                                                                                                                                                                                                                                                                              |                                                                                                 |  |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--|
|             |          |                                                                                                                                                                                                                                                                                              | Standby mode                                                                                    |  |
|             |          | Bit 1 (nDEPSLP_RST)                                                                                                                                                                                                                                                                          | 0: Reset occurs when entering Deepsleep mode<br>1: No reset occurs when entering Deepsleep mode |  |
|             |          | Bit 0 (nWDT_ATO_EN)                                                                                                                                                                                                                                                                          | 0: Watchdog is enabled<br>1: Watchdog is disabled                                               |  |
|             | [31: 24] | nSSB[7: 0]: Inverse code of SSB[7: 0]                                                                                                                                                                                                                                                        |                                                                                                 |  |
| 0x1FFF_C004 | [7: 0]   | Data0[7: 0]: User data 0 (It is stored in the FLASH_USD[17:10] register)                                                                                                                                                                                                                     |                                                                                                 |  |
|             | [15: 8]  | nData0[7: 0]: Inverse code of Data0[7: 0]                                                                                                                                                                                                                                                    |                                                                                                 |  |
|             | [23: 16] | Data1[7: 0]: User data 1 (It is stored in the FLASH_USD[25: 18] register)                                                                                                                                                                                                                    |                                                                                                 |  |
|             | [31: 24] | nData1[7: 0]: Inverse code of Data1[7: 0]                                                                                                                                                                                                                                                    |                                                                                                 |  |
|             | [7: 0]   | EPP0[7: 0]: Flash erase/write protection byte 0 (in the FLASH_EPPS[7: 0])<br><br>This field is used to protect the 1st~32nd KB of main Flash memory.<br>Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled                |                                                                                                 |  |
| 0x1FFF_C008 | [15: 8]  | nEPP0[7: 0]: Inverse code of EPP0[7: 0]                                                                                                                                                                                                                                                      |                                                                                                 |  |
|             | [23: 16] | EPP1[7:0]: Flash erase/write protection byte 1 (stored in the FLASH_EPPS[15: 8])<br><br>This field is used to protect the 33rd~64th KB of main Flash memory.<br>Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled        |                                                                                                 |  |
|             | [31: 24] | nEPP1[7: 0]: Inverse code of EPP1[7: 0]                                                                                                                                                                                                                                                      |                                                                                                 |  |
|             | [7: 0]   | EPP2[7:0]: Flash erase/write protection byte 2 (stored in the FLASH_EPPS[23: 16])<br><br>This field is used to protect the 65th~96th KB of main Flash memory.<br>Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled       |                                                                                                 |  |
|             | [15: 8]  | nEPP2[7: 0]: Inverse code of EPP2[7: 0]                                                                                                                                                                                                                                                      |                                                                                                 |  |
| 0x1FFF_C00C | [23: 16] | EPP3[7:0]: Flash erase/write protection byte 3 (stored in the FLASH_EPPS[31: 24])<br><br>This field is used to protect the 97th~128th KB of main Flash memory.<br>Each bit takes care of 4 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled      |                                                                                                 |  |
|             | [31: 24] | nEPP3[7: 0]: Inverse code of EPP3[7: 0]                                                                                                                                                                                                                                                      |                                                                                                 |  |
|             | [7: 0]   | EOPB0[7: 0]: Extended system options<br>Refer to Table 5-5 for more details.                                                                                                                                                                                                                 |                                                                                                 |  |
|             | [15: 8]  | nEOPB0[7: 0]: Inverse code of EOPB0[7: 0]                                                                                                                                                                                                                                                    |                                                                                                 |  |
|             | [31: 16] | Reserved                                                                                                                                                                                                                                                                                     |                                                                                                 |  |
| 0x1FFF_C010 | [7: 0]   | EPP4[7: 0]:<br>Flash erase/write protection byte 4 (stored in the FLASH_EPPS1[7: 0])<br><br>This field is used to protect the 129th~1152nd KB of main Flash memory. Each bit takes care of 128 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled  |                                                                                                 |  |
|             | [15: 8]  | nEPP4[7: 0]: Inverse code of EPP4 [7: 0]                                                                                                                                                                                                                                                     |                                                                                                 |  |
|             | [23: 16] | EPP5[7:0]:<br>Flash erase/write protection byte 5 (stored in the FLASH_EPPS1[15: 8])<br><br>This field is used to protect the 1153rd~2176th KB of main Flash memory. Each bit takes care of 128 KB sectors.<br>0: Erase/write protection is enabled<br>1: Erase/write protection is disabled |                                                                                                 |  |
|             | [31: 24] | nEPP5 [7: 0]: Inverse code of EPP5[7: 0]                                                                                                                                                                                                                                                     |                                                                                                 |  |
|             | [7: 0]   | EPP6[7:0]:<br>Flash erase/write protection byte 6 (stored in the FLASH_EPPS1[23: 16])<br><br>Bit 7 is reserved.<br>Bit [6:0] is used to protect the 2177th~3200th KB of main Flash memory. Each bit takes care of 128 KB sectors.                                                            |                                                                                                 |  |
| 0x1FFF_C018 |          |                                                                                                                                                                                                                                                                                              |                                                                                                 |  |

|                                                                                        |                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                        |                                                                                                                                                                                                                                                                     | 0: Erase/write protection is enabled<br>1: Erase/write protection is disabled                                                                                                                                                                                                                                                                                                     |
| [15: 8]                                                                                |                                                                                                                                                                                                                                                                     | nEPP6[7: 0]: Inverse code of EPP6[7: 0]                                                                                                                                                                                                                                                                                                                                           |
| [23: 16]                                                                               | EPP7[7:0]:<br>Flash erase/write protection byte 7 (stored in the FLASH_EPPS1[31: 24])<br>Bit 7 is reserved.<br>Bit 6:0 is used to protect the 3201st~4032nd KB of main Flash memory. Each bit takes care of 128 KB sectors.<br>0: Erase/write protection is enabled |                                                                                                                                                                                                                                                                                                                                                                                   |
| [31: 24]                                                                               |                                                                                                                                                                                                                                                                     | nEPP7 [7: 0]: Inverse code of EPP7[7: 0]                                                                                                                                                                                                                                                                                                                                          |
| 0x1FFF_C01C<br>0x1FFF_C020<br>0x1FFF_C024<br>0x1FFF_C028<br>0x1FFF_C02C<br>0x1FFF_C030 | [31: 0]                                                                                                                                                                                                                                                             | Reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 0x1FFF_C034                                                                            | [7: 0]                                                                                                                                                                                                                                                              | QSPIKEY0 [7: 0]: QuadSPI (QSPI) ciphertext access area encryption key byte 0<br>The situations for non-encryption includes:<br>Both 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 and 0x00FF. Among them, QSPIKEY0-QSPIKEY3 are the encrypted key of QSPI1. |
|                                                                                        | [15: 8]                                                                                                                                                                                                                                                             | nQSPIKEY0[7: 0]: Inverse code of QSPIKEY0[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | QSPIKEY1[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 1                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | nQSPIKEY1[7: 0]: Inverse code of QSPIKEY1[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [7: 0]                                                                                                                                                                                                                                                              | QSPIKEY2[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 2                                                                                                                                                                                                                                                                                                                   |
| 0x1FFF_C038                                                                            | [15: 8]                                                                                                                                                                                                                                                             | nQSPIKEY2[7:0]: Inverse code of QSPIKEY2 [7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | QSPIKEY3[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 3                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | nQSPIKEY3[7: 0]: Inverse code of QSPIKEY3[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [7: 0]                                                                                                                                                                                                                                                              | QSPIKEY4[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 4                                                                                                                                                                                                                                                                                                                   |
| 0x1FFF_C03C                                                                            | [15: 8]                                                                                                                                                                                                                                                             | nQSPIKEY4[7: 0]: Inverse code of QSPIKEY4[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | QSPIKEY5[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 5                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | nQSPIKEY5[7: 0]: Inverse code of QSPIKEY5[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [7: 0]                                                                                                                                                                                                                                                              | QSPIKEY6[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 6                                                                                                                                                                                                                                                                                                                   |
| 0x1FFF_C040                                                                            | [15: 8]                                                                                                                                                                                                                                                             | nQSPIKEY6[7: 0]: Inverse code of QSPIKEY6[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | EXT_FLASH_KEY7[7: 0]: External memory ciphertext encryption key byte 7                                                                                                                                                                                                                                                                                                            |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | QSPIKEY7[7: 0]: QuadSPI (QSPI) ciphertext encryption key byte 7                                                                                                                                                                                                                                                                                                                   |
| 0x1FFF_C044<br>0x1FFF_C048                                                             | [31: 0]                                                                                                                                                                                                                                                             | Reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 0x1FFF_C04C                                                                            | [7: 0]                                                                                                                                                                                                                                                              | Data2[7: 0]: User data2                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                        | [15: 8]                                                                                                                                                                                                                                                             | nData2[7: 0]: Inverse code of Data2[7: 0]                                                                                                                                                                                                                                                                                                                                         |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | Data3[7: 0]: User data3                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | nData3[7: 0]: Inverse code of Data3[7: 0]                                                                                                                                                                                                                                                                                                                                         |
| ..                                                                                     | ..                                                                                                                                                                                                                                                                  | ..                                                                                                                                                                                                                                                                                                                                                                                |
| 0x1FFF_C1FC                                                                            | [7: 0]                                                                                                                                                                                                                                                              | Data218[7: 0]: User data218                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                        | [15: 8]                                                                                                                                                                                                                                                             | nData218[7: 0]: Inverse code of Data218[7: 0]                                                                                                                                                                                                                                                                                                                                     |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | Data219[7: 0]: User data219                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | nData219[7: 0]: Inverse code of Data219[7: 0]                                                                                                                                                                                                                                                                                                                                     |
| ..                                                                                     | ..                                                                                                                                                                                                                                                                  | ..                                                                                                                                                                                                                                                                                                                                                                                |
| 0x1FFF_CFFC                                                                            | [7: 0]                                                                                                                                                                                                                                                              | Data2010[7: 0]: User data2010                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                        | [15: 8]                                                                                                                                                                                                                                                             | nData2010[7: 0]: Inverse code of Data2010[7: 0]                                                                                                                                                                                                                                                                                                                                   |
|                                                                                        | [23: 16]                                                                                                                                                                                                                                                            | Data2011[7: 0]: User data2011                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                        | [31: 24]                                                                                                                                                                                                                                                            | nData2011[7: 0]: Inverse code of Data2011[7: 0]                                                                                                                                                                                                                                                                                                                                   |

Note:

- For 1024 KB Flash memory and 256 KB Flash memory, there are 256 bytes of user system data, ranging

from 0x1FFF\_C000 to 0x1FFF\_C1FF, including 220 bytes of user data.

2. For 4032 KB Flash memory and 448 KB Flash memory, there are 2048 bytes of user system data, ranging from 0x1FFF\_C000 to 0x1FFF\_CFFF, including 2012 bytes of user data.

3. For 448 KB Flash memory, only EPP0[7:0], EPP1[7:0], EPP2[7:0], EPP3[7:0] and EPP4[2:0] bits are configurable, and other EPPx bits must be fixed to 1.

Table 5-6 Extended system options

| EOPB0[7: 0]: Extended system option |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 256 K Flash                         | Bit 1: 0 | 00: On-chip 512 KB SRAM+128 KB zero-wait-state Flash<br>01: On-chip 448 KB SRAM+192 KB zero-wait-state Flash<br>10, 11: On-chip 384 KB SRAM+256 KB zero-wait-state Flash<br>Note: Bit 1~0 can be altered only when security library is disabled.                                                                                                                                                                                                                                         |
|                                     | Bit 7: 2 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 448 K Flash                         | Bit 2: 0 | 000: On-chip 512KB SRAM + 128KB zero-wait-state Flash<br>001: On-chip 448KB SRAM + 192KB zero-wait-state Flash<br>010: On-chip 384KB SRAM + 256KB (default) zero-wait-state Flash<br>011: On-chip 320KB SRAM + 320KB zero-wait-state Flash<br>100: On-chip 256KB SRAM + 384KB zero-wait-state Flash<br>101, 110, 111: On-chip 192KB SRAM + 448KB zero-wait-state Flash<br>Note: Bit 2~0 can be altered only when security library is disabled.                                           |
|                                     | Bit 7: 3 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1024 K and above Flash              | Bit 2: 0 | 000: On-chip 512 KB SRAM+128 KB zero-wait-state Flash<br>001: On-chip 448 KB SRAM+192 KB zero-wait-state Flash<br>010: On-chip 384 KB SRAM+256 KB zero-wait-state Flash<br>011: On-chip 320 KB SRAM+320 KB zero-wait-state Flash<br>100: On-chip 256 KB SRAM+384 KB zero-wait-state Flash<br>101: On-chip 192 KB SRAM+448 KB zero-wait-state Flash<br>110, 111: On-chip 128 KB SRAM+512 KB zero-wait-state Flash<br>Note: Bit 2~0 can be altered only when security library is disabled. |
|                                     | Bit 7: 3 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## 5.2 Flash memory operation

### 5.2.1 Unlock/lock

After reset, Flash memory is protected, by default. FLASH\_CTRLx 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\_UNLOCKx 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\_CTRLx register.

### 5.2.2 Erase operation

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

#### Sector erase

Any sector in the Flash memory can be erased with sector erase function independently. Below should be followed during sector erase:

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

Figure 5-1 Flash memory sector erase process

**Block erase:**

Any block of Flash memory can be erased independently.

The following process is recommended:

- Check the OBF bit in the `FLASH_STSx` register to confirm that there is no other programming operation in progress;
- Write the block to be erased in the `FLASH_ADDRx` register;
- Set the BANKERS and ERSTR bits in the `FLASH_CTRLx` register to enable block erase;
- Wait until the OBF bit becomes “0” in the `FLASH_STSx` register. Read the EPPERR bit and ODF bit in the `FLASH_STSx` register to verify the erased blocks.

Figure 5-2 Flash memory block erase process



### Mass erase

Mass erase function can erase all the Flash memory.

The following process is recommended:

- Check the OBF bit in the FLASH\_STSx register to confirm that there is no other programming operation in progress;
- Set the BANKERS and ERSTR bits in the FLASH\_CTRLx register to enable mass erase;
- Wait until the OBF bit becomes “0” in the FLASH\_STSx register. Read the EPPERR bit and ODF bit in the FLASH\_STSx register to verify the erased sectors.

*Note: Read operation to the Flash memory during erase will halt CPU until the completion of erase.*

Figure 5-3 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\_STSx register to confirm that there is no other programming operation in progress;
- Set the FPRGM bit in the FLASH\_CTRLx 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\_STSx register becomes “0”, read the EPPERR, PRGMERR and ODF bit to verify the programming result.

*Note:*

1. 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\_STSx register.
2. Read operation to the Flash memory during programming will halt CPU until the completion of programming.

Figure 5-4 Flash memory programming process



## 5.2.4 Read operation

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

## 5.3 User system data area operation

### 5.3.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 block can be unlocked by writing KEY1 (0x45670123) and KEY2 (0xCDEF89AB) to the FLASH\_UNLOCK register;

When KEY1 (0x45670123) and KEY2 (0xCDEF89AB) is 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 by software.

### 5.3.2 Erase operation

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

Below should be followed during erase operation:

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

*Note: Read operation to the Flash memory during programming will halt CPU until the completion of erase.*

Figure 5-5 System data area erase process



### 5.3.3 Programming operation

The User system data area can be programmed with 16 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 the USDPROM bit in the FLASH\_CTRL register, so that the programming instructions for the user system data area can be received;
- Write the data (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 bit to verify the programming result.

*Note:* 1. Read operation to the Flash memory during programming will halt CPU until the completion of programming.  
2. Writing non-0xA5 value to the FAP byte is not allowed.

Figure 5-6 System data area programming process



### 5.3.4 Read operation

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

## 5.4 Flash memory protection

Flash memory includes access and erase/program protection.

### 5.4.1 Access protection

When the contents in the nFAP and FAP byte are different from 0x5A and 0xA5, the Flash memory will activate access protection after a system reset. In this case, 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.

When the Flash access is protected, the user can re-erase the system data area, and unlock Flash access protection (switching from protected to unprotected state will trigger mass erase on the Flash memory 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)

*Note: 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-7 shows Flash memory access limits when Flash access protection is enabled.

Table 5-7 Flash memory access limit

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

(1)Main Flash memory is cleared automatically by hardware only when the access protection is disabled;

(2)Only sector erase and block erase are forbidden. Bank 1 and bank 2 mass erase are not affected.

### 5.4.2 Erase/program protection

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:

- The sectors with erase/program protection enabled
- The blocks with erase/program protection enabled
- Bank1, bank2 with erase/program protection enabled
- When the Flash access protection is enabled, the first 4 KB in the main Flash memory will be protected against erase/program automatically,
- Once the Flash access protection is enabled, the main Flash memory is protected against erase/program when it is in debug mode or when it is started from non-main Flash memory.

## 5.5 Special functions

### 5.5.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 read (Except for I-Code and D-code buses), written, or deleted, unless a correct code is keyed in. Security library includes instruction security library and data security library.

**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 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 can only be located in the main Flash memory;*

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

*Only I-Code bus is allowed to read instruction security library;*

*Only I-Code and D-Code bus are allowed to read the read-only area;*

*In an attempt of writing or deleting 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 into the security library setting register.

Optional CRC check for security library code is based on a sector level.

The steps to enable security library are as follows:

- Check the OBF bit in the FLASH\_STS register to ensure that there is no other ongoing programming operation;
- Write 0xA35F6D24 to the SLIB\_UNLOCK register to unlock security library;
- Check the SLIB\_ULKF bit of SLIB\_MISC\_STS register to verify that it is unlocked successfully;
- Set a security password in the SLIB\_SET\_PWD register;
- Set the area to be protected in the SLIB\_SET\_RANGE0 and SLIB\_SET\_RANGE1 register;
- Enable the security library information settings by setting the SET\_SLIB\_STRT bit in the SLIB\_SET\_RANGE1 register;
- Wait until the OBF bit becomes “0”;
- Program the code to be saved in security library;
- Perform system reset, and then reload security library setting word;
- Read the SLIB\_STS0/STS1/STS2 register to verify the security library settings.

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

Steps to unlock security library:

- Write the previously set security library password to the SLIB\_PWD\_CLR register;
- Wait until the OBF bit becomes “0”;
- Perform system reset, and then reload security library setting word;
- Read the SLIB\_STS0 register to check the security library settings.

*Note: Disabling the security library will automatically perform mass erase for the main memory and for security library setting block.*

## 5.5.2 CRC calculation unit

CRC calculation can be performed on a sector level to check the security library code or user code inside bank 1 and bank 2.

- 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

Follow the procedure below:

- Check that no Flash memory operation is ongoing by checking the OBF bit in the FLASH\_STS register
- Set the start sector and select the desired sector you wish to do CRC in the FLASH\_CRC\_CTRL register
- Enable CRC by setting the bit 31 in the FLASH\_CRC\_CTRL register
- Wait for the OBF bit to 0 (be cleared)
- Obtain CRC result by reading the FLASH\_CRC\_CHK register

*Note: Cross-boundary CRC check is forbidden for both the security library and user system data area.*

## 5.6 Flash memory registers

Table 5-8 lists Flash register map and their reset values.

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

Table 5-8 Flash memory interface—Register map and reset value

| Register         | Offset | Reset value |
|------------------|--------|-------------|
| FLASH_PSR        | 0x00   | 0x0000 0330 |
| FLASH_UNLOCK     | 0x04   | 0xXXXX XXXX |
| FLASH_USD_UNLOCK | 0x08   | 0xXXXX XXXX |
| FLASH_STS        | 0x0C   | 0x0000 0000 |
| FLASH_CTRL       | 0x10   | 0x0000 0080 |
| FLASH_ADDR       | 0x14   | 0x0000 0000 |
| FLASH_USD        | 0x1C   | 0x03FF FFFC |
| FLASH_EPPS0      | 0x20   | 0xFFFF FFFF |
| FLASH_EPPS1      | 0x2C   | 0xFFFF FFFF |
| FLASH_UNLOCK2    | 0x44   | 0xXXXX XXXX |
| FLASH_STS2       | 0x4C   | 0x0000 0000 |
| FLASH_CTRL2      | 0x50   | 0x0000 0080 |
| FLASH_ADDR2      | 0x54   | 0x0000 0000 |
| FLASH_CONTR      | 0x58   | 0x0000 0080 |
| FLASH_DIVR       | 0x60   | 0x0000 0022 |
| SLIB_STS2        | 0xC8   | 0x0000 FFFF |
| SLIB_STS0        | 0xCC   | 0x0000 0000 |
| SLIB_STS1        | 0xD0   | 0xFFFF FFFF |
| SLIB_PWD_CLR     | 0xD4   | 0x0000 0000 |
| SLIB_MISC_STS    | 0xD8   | 0x0100 0000 |
| SLIB_SET_PWD     | 0xDC   | 0x0000 0000 |
| SLIB_SET_RANGE0  | 0xE0   | 0x0000 0000 |
| SLIB_SET_RANGE1  | 0xE4   | 0x0000 0000 |

|                |      |             |
|----------------|------|-------------|
| SLIB_UNLOCK    | 0xF0 | 0x0000 0000 |
| FLASH_CRC_CTRL | 0xF4 | 0x0000 0000 |
| FLASH_CRC_CHK  | 0xF8 | 0x0000 0000 |

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

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                             |
|------------|-------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved    | 0x00000     | resd | Kept at its default value.                                                                                                                                                                                                                                              |
| Bit 13     | NZW_BST_STS | 0x0         | ro   | Flash non-zero wait area boost status<br>0: Flash non-zero wait area boost status disabled<br>1: Flash non-zero wait area boost status enabled                                                                                                                          |
|            |             |             |      | Flash non-zero wait area boost<br>0: Flash non-zero wait area boost disabled<br>1: Flash non-zero wait area boost enabled                                                                                                                                               |
| Bit 12     | NZW_BST     | 0x0         | rw   | Note:<br>Enabling this feature will increase the operating efficiency of non-zero wait state Flash memory, but the system frequency will be limited. Refer to data sheet for more information.<br>The setting code of this bit is located in the zero-wait state Flash. |
| Bit 11: 0  | Reserved    | 0x330       | resd | Kept at its default value.                                                                                                                                                                                                                                              |

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

Only used in Flash memory bank 1.

| Bit       | Name  | Reset value    | Type | Description                                                     |
|-----------|-------|----------------|------|-----------------------------------------------------------------|
| Bit 31: 0 | UKVAL | 0xFFFF XXXX wo |      | Unlock key value<br>This is used to unlock Flash memory bank 1. |

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

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

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

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

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

Only used in Flash memory bank 1.

| Bit       | Name     | Reset value | Type | Description                                                                                                                  |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 6 | Reserved | 0x0000000   | resd | Kept at its default value                                                                                                    |
|           |          |             |      | Operation done flag                                                                                                          |
| Bit 5     | ODF      | 0x0         | rw   | This bit is set by hardware when Flash memory operations (program/erase) is completed. It is cleared by writing “1”.         |
|           |          |             |      | Erase/program protection error                                                                                               |
| Bit 4     | EPPERR   | 0x0         | rw   | This bit is set by hardware when programming the erase/program-protected Flash memory address. It is cleared by writing “1”. |
| Bit 3     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                   |
|           |          |             |      | Programming error                                                                                                            |
| Bit 2     | PRGMERR  | 0x0         | rw   | When the programming address is in non-erase state, this bit is set by hardware. It is cleared by writing “1”.               |
| Bit 1     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                   |
|           |          |             |      | Operation busy flag                                                                                                          |
| Bit 0     | OBF      | 0x0         | ro   | When this bit is set, it indicates that Flash memory operation is in progress. It is cleared when operation is completed.    |

## 5.6.5 Flash control register (FLASH\_CTRL)

Only used in Flash memory bank 1.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 13 | Reserved | 0x00000     | resd | Kept at its default value                                                                                                                                                                                                                                    |
|            |          |             |      | Operation done flag interrupt enable                                                                                                                                                                                                                         |
| Bit 12     | ODFIE    | 0x0         | rw   | 0: Interrupt is disabled;<br>1: Interrupt is enabled.                                                                                                                                                                                                        |
| Bit 11,8   | Reserved | 0x0         | resd | Kept its default value                                                                                                                                                                                                                                       |
|            |          |             |      | Error interrupt enable                                                                                                                                                                                                                                       |
| Bit 10     | ERRIE    | 0x0         | rw   | This bit enables EPPERR or PROGERR interrupt.<br>0: Interrupt is disabled;<br>1: Interrupt is enabled.                                                                                                                                                       |
|            |          |             |      | User system data unlock success                                                                                                                                                                                                                              |
| Bit 9      | USDULKS  | 0x0         | rw   | 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.                    |
|            |          |             |      | Operation lock                                                                                                                                                                                                                                               |
| Bit 7      | OPLK     | 0x1         | rw   | 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 re-lock Flash memory operations. |
|            |          |             |      | Erase start                                                                                                                                                                                                                                                  |
| Bit 6      | ERSTR    | 0x0         | rw   | An erase operation is triggered when this bit is set. This bit is cleared by hardware after the completion of the erase operation.                                                                                                                           |
|            |          |             |      | User system data erase                                                                                                                                                                                                                                       |
| Bit 5      | USDERS   | 0x0         | rw   | It indicates the user system data erase.                                                                                                                                                                                                                     |
|            |          |             |      | User system data program                                                                                                                                                                                                                                     |
| Bit 4      | USDPRGM  | 0x0         | rw   | It indicates the user system data program.                                                                                                                                                                                                                   |
|            |          |             |      | Block erase                                                                                                                                                                                                                                                  |
| Bit 3      | BLKERS   | 0x0         | rw   | It indicates block erase operation.                                                                                                                                                                                                                          |
|            |          |             |      | Bank erase                                                                                                                                                                                                                                                   |
| Bit 2      | BANKERS  | 0x0         | rw   | It indicates bank erase operation.                                                                                                                                                                                                                           |
|            |          |             |      | Sector erase                                                                                                                                                                                                                                                 |
| Bit 1      | SECERS   | 0x0         | rw   | It indicates sector erase operation.                                                                                                                                                                                                                         |
|            |          |             |      | Flash program                                                                                                                                                                                                                                                |
| Bit 0      | FPRGM    | 0x0         | rw   | It indicates Flash program operation.                                                                                                                                                                                                                        |

## 5.6.6 Flash address register (FLASH\_ADDR)

Only used in Flash memory bank 1.

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

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

| Bit        | Name     | Reset value | Type | Description                                                           |
|------------|----------|-------------|------|-----------------------------------------------------------------------|
| Bit 31: 26 | Reserved | 0x00        | resd | Kept at its default value                                             |
| Bit 25: 18 | USER_D1  | 0xFF        | ro   | User data 1                                                           |
| Bit 17: 10 | USER_D0  | 0xFF        | ro   | User data 0                                                           |
|            |          |             |      | System setting byte                                                   |
| Bit 9: 2   | SSB      | 0xFF        | ro   | Includes the system setting bytes in the loaded user system data area |
|            |          |             |      | Bit 9: Unused                                                         |

|       |        |     |    |                                                                                                                                                                                                                                    |
|-------|--------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     |    | Bit 8: nSTDBY_WDT<br>Bit 7: nDEPSLP_WDT<br>Bit 6: Unused<br>Bit 5: BTOPT<br>Bit 4: nSTDBY_RST<br>Bit 3: nDEPSLP_RST<br>Bit 2: nWDT_ATO_EN                                                                                          |
| Bit 1 | FAP    | 0x0 | ro | Flash access protection<br>Access to Flash memory is not allowed when this bit is set.                                                                                                                                             |
| Bit 0 | USDERR | 0x0 | 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.6.8 Erase/program protection status register 0 (FLASH\_EPPS0)

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

## 5.6.9 Erase/program protection status register 1 (FLASH\_EPPS1)

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

## 5.6.10 Flash unlock register 2 (FLASH\_UNLOCK2)

Only used in Flash memory bank 2.

| Bit       | Name  | Reset value | Type | Description                                                              |
|-----------|-------|-------------|------|--------------------------------------------------------------------------|
| Bit 31: 0 | UKVAL | 0xFFFF FFFF | wo   | Unlock key value<br>This register is used to unlock Flash memory bank 2. |

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

## 5.6.11 Flash status register 2 (FLASH\_STS2)

Only used in Flash memory bank 2.

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

---

completed.

---

### 5.6.12 Flash control register 2 (FLASH\_CTRL2)

Only used in Flash memory bank 2.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 13 | Reserved | 0x00000     | resd | Kept its default value                                                                                                                                                                                                                                       |
|            |          |             |      | Operation done flag interrupt enable                                                                                                                                                                                                                         |
| Bit 12     | ODFIE    | 0x0         | rw   | 0: Interrupt is disabled;<br>1: Interrupt is enabled.                                                                                                                                                                                                        |
| Bit 11     | Reserved | 0x0         | resd | Kept its default value                                                                                                                                                                                                                                       |
|            |          |             |      | Error interrupt enable                                                                                                                                                                                                                                       |
| Bit 10     | ERRIE    | 0x0         | rw   | This bit enables EPPERR or PROGERR interrupt.<br>0: Interrupt is disabled;<br>1: Interrupt is enabled.                                                                                                                                                       |
| Bit 9,8    | Reserved | 0x0         | resd | Kept at its default value                                                                                                                                                                                                                                    |
|            |          |             |      | Operation lock                                                                                                                                                                                                                                               |
| Bit 7      | OPLK     | 0x1         | rw   | 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 re-lock Flash memory operations. |
|            |          |             |      | Erase start                                                                                                                                                                                                                                                  |
| Bit 6      | ERSTR    | 0x0         | rw   | An erase operation is triggered when this bit is set. This bit is cleared by hardware after the completion of the erase operation.                                                                                                                           |
| Bit 5,4    | Reserved | 0x0         | resd | Kept its default value                                                                                                                                                                                                                                       |
| Bit 3      | BLKERS   | 0x0         | rw   | Block erase<br>It indicates block erase operation.                                                                                                                                                                                                           |
| Bit 2      | BANKERS  | 0x0         | rw   | Bank erase<br>It indicates bank erase operation.                                                                                                                                                                                                             |
| Bit 1      | SECERS   | 0x0         | rw   | Sector erase<br>It indicates sector erase operation.                                                                                                                                                                                                         |
| Bit 0      | FPRGM    | 0x0         | rw   | Flash program<br>It indicates Flash program operation.                                                                                                                                                                                                       |

---

### 5.6.13 Flash address register 2 (FLASH\_ADDR2)

Only used in Flash memory bank 2.

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

---

### 5.6.14 Flash continue read register (FLASH\_CONTR)

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                                                                                            |
|-----------|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | FCONTR_EN | 0x0         | rw   | Flash continue read enable<br>0: Flash continue read mode disabled<br>1: Flash continue read mode enabled<br>Setting this bit will enable the CPU to read Flash at a faster speed, but will also increase power consumption of Flash at the same time. |
| Bit 30: 0 | Reserved  | 0x0000 0080 | resd | Kept at its default value.                                                                                                                                                                                                                             |

---

## 5.6.15 Flash divider register (FLASH\_DIVR)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                 |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 6 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                  |
|           |          |             |      | Flash divider status<br>This field indicates the division relationship between the current Flash interface and HCLK.<br>0: HCLK/2<br>1: HCLK/3<br>Others: HCLK/4                                                            |
| Bit 5: 4  | FDIV_STS | 0x2         | ro   |                                                                                                                                                                                                                             |
| Bit 3: 2  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                  |
|           |          |             |      | Flash divider<br>This field is used to configure the division relationship between the Flash interface and HCLK.<br>0: HCLK/2<br>1: HCLK/3<br>Others: HCLK/4<br>Note: The Flash interface clock is not greater than 104MHz. |
| Bit 1: 0  | FDIV     | 0x2         | rw   |                                                                                                                                                                                                                             |

## 5.6.16 Flash security library status register 2 (SLIB\_STS2)

Only used in Flash security library.

| Bit        | Name         | Reset value | Type | Description                                                 |
|------------|--------------|-------------|------|-------------------------------------------------------------|
| Bit 31: 16 | Reserved     | 0x0000      | resd | Kept at its default value                                   |
|            |              |             |      | sLib instruction start sector<br>0: Sector 0<br>1: Sector 1 |
| Bit 15: 0  | SLIB_INST_SS | 0xFFFF      | ro   | 2: Sector 2<br>...<br>0xFFFF: Non-sLib instruction          |

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

Only used in Flash security library.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                     |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 4 | Reserved | 0x0000000   | resd | Kept at its default value                                                                                                                                       |
|           |          |             |      | SLIB_ENF: sLib enable flag                                                                                                                                      |
| Bit 3     | SLIB_ENF | 0x0         | ro   | 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 code. |

Bit 2: 0 Reserved 0x0 resd Keep at its default value

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

Only used in Flash security library.

| Bit        | Name    | Reset value | Type | Description                                                                       |
|------------|---------|-------------|------|-----------------------------------------------------------------------------------|
| Bit 31: 16 | SLIB_ES | 0xFFFF      | ro   | Security library end sector<br>0: Sector 0<br>1: Sector 1<br>2: Sector 2<br>...   |
| Bit 15: 0  | SLIB_SS | 0xFFFF      | ro   | Security library start sector<br>0: Sector 0<br>1: Sector 1<br>2: Sector 2<br>... |

### 5.6.19 Flash security library password clear register (SLIB\_PWD\_CLR)

Only used in Flash security library.

| Bit      | Name          | Reset value | Type | Description                                                                                                                                                                                                                         |
|----------|---------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:0 | SLIB_PCLR_VAL | 0x0000 0000 | wo   | Security library password clear value<br>Entering correct security library password will unlock security library functions.<br>The write status of this register is reflected in the bit 0 and bit 1 in the SLIB_MISC_STS register. |

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

Only used in Flash security library.

| Bit        | Name         | Reset value | Type | Description                                                                                                                                                                                                                                                                                                        |
|------------|--------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31:25  | Reserved     | 0x00        | resd | Kept at its default value                                                                                                                                                                                                                                                                                          |
| Bit 24: 16 | SLIB_RCNT    | 0x100       | ro   | Security library remaining count<br>It is decremented from 256 to 0.                                                                                                                                                                                                                                               |
| Bit 15: 3  | Reserved     | 0x0000      | resd | Kept at its default value                                                                                                                                                                                                                                                                                          |
| Bit 2      | SLIB_ULKF    | 0x0         | ro   | Security library unlock flag<br>When this bit is set, it indicates that sLib-related setting registers can be configured.                                                                                                                                                                                          |
| Bit 1      | SLIB_PWD_OK  | 0x0         | ro   | Security library password ok<br>This bit is set by hardware when the password is correct.                                                                                                                                                                                                                          |
| Bit 0      | SLIB_PWD_ERR | 0x0         | ro   | Security library 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.6.21 Security library password setting register (SLIB\_SET\_PWD)

Only used in Flash security library.

| Bit       | Name          | Reset value | Type | Description                                                                                                                                                                                                                                 |
|-----------|---------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | SLIB_PSET_VAL | 0x0000 0000 | wo   | Security library password setting value<br>Note: This register can be written only after unlocking security library lock. It is used to set up the startup password of security library. Values of 0xFFFF_FFFF and 0x0000_0000 are invalid. |

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

### 5.6.22 Security library address setting register0 (SLIB\_SET\_RANGE0)

Only used for Flash security library address setting.

| Bit        | Name        | Reset value | Type | Description                                                                                                                                            |
|------------|-------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | SLIB_ES_SET | 0x000       | wo   | Security library end sector setting<br>These bits are used to set the security library end sector.<br>0: Sector 0<br>1: Sector 1<br>2: Sector 2<br>... |
| Bit 10: 0  | SLIB_SS_SET | 0x000       | wo   | Security library start sector setting<br>These bits are used to set the security library start sector.                                                 |

0: Sector 0  
1: Sector 1  
2: Sector 2  
...

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

- (1) This register can be written only after unlocking security library lock.
- (2) Being out of the Flash address range is an invalid setting.

### 5.6.23 Security library address setting register 1 (SLIB\_SET\_RANGE1)

Only used for Flash security library address setting.

| Bit        | Name          | Reset value | Type | Description                                                                                                                                                                                                        |
|------------|---------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | SET_SLIB_STRT | 0x0         | wo   | Setting sLib start<br>This bit is used to enable security library information settings.<br>It is cleared by hardware automatically when the security library configuration is enabled by hardware.                 |
| Bit 30: 16 | Reserved      | 0x0000      | resd | Kept at its default value                                                                                                                                                                                          |
| Bit 15: 0  | SLIB_ISS_SET  | 0x0000      | wo   | Security library instruction start sector setting<br>These bits are used to set the security library instruction start sector.<br>0: Sector 0<br>1: Sector 1<br>2: Sector 2<br>...<br>0xFFFF: Non-sLib instruction |

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

Only used for Flash security library unlock setting.

| Bit       | Name       | Reset value | Type | Description                                                                                                            |
|-----------|------------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | SLIB_UKVAL | 0x0000 0000 | wo   | Security library unlock key value<br>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.*

### 5.6.25 Flash CRC calibration control register (FLASH\_CRC\_CTRL)

Only used in main Flash memory.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                         |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | CRC_STRT | 0x0         | wo   | CRC start<br>Set this bit to enable user code or security library code CRC check. This bit is cleared automatically after the hardware enables CRC. |
| Bit 30: 24 | Reserved | 0x00        | wo   | Kept at its default value                                                                                                                           |
| Bit 23: 12 | CRC_SN   | 0x000       | wo   | CRC sector number<br>Set the number of the CRC calibration, in terms of sectors.                                                                    |
| Bit 11: 0  | CRC_SS   | 0x000       | wo   | CRC calibration start sector<br>Set the start sector for this CRC calibration.<br>0x0: Sector 0<br>0x1: Sector 1<br>...                             |

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

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

Only used in Flash or security library.

| 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 0 when being written.*

## 6 GPIOs and IOMUX

### 6.1 Introduction

AT32F435 series supports up to 116 bidirectional I/O pins, namely PA0-PA15, PB0-PB15, PC0-PC15, PD0-PD15, PE0-PE15, PF0-PF15, PG0-PG15 and PH0-PH3. 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 MUX mode, each pin 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 are configured as floating input mode except JTAG-related pins. JTAG pin configuration are as follows:

- PA15/JTDI, PA13/JTMS and PB4/JNTRST in multiplexed pull-up mode;
- PA14/JTCK in multiplexed pull-down mode;
- PB3/TDO in multiplexed mode without pull-up/pull-down capability

### 6.2.3 General-purpose input configuration

| Mode            | IOMC | PULL     |
|-----------------|------|----------|
| Floating input  |      | 00 or 11 |
| 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 interference 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  |                                                                                                                                                                                                                                                                            |            | 01       |
| Push-pull with pull-down             | 01   | 1  | 000: Output mode, normal sourcing/sinking strength<br>001: Output mode, large sourcing/sinking strength<br>010: Output mode, normal sourcing/sinking strength<br>011: Output mode, normal sourcing/sinking strength<br>1xx: Output mode, Maximum sourcing/sinking strength |            | 10       |
| Open-drain without pull-up/pull-down | 01   | 1  |                                                                                                                                                                                                                                                                            |            | 00 or 11 |
| Open-drain with pull-up              |      |    |                                                                                                                                                                                                                                                                            |            | 01       |
| Open-drain with pull-down            | 01   | 1  |                                                                                                                                                                                                                                                                            |            | 10       |

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

- Schmitt-trigger input is enabled.
- 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 pull-up/pull-down; or the pin is pulled up to 1 or pulled down to 0 if there is an internal pull-up or pull-down.
- In push-pull 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 IOC<sub>B</sub> and IOS<sub>B</sub> bits are set in the GPIO set/clear register, the IOS<sub>B</sub> 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 pin 0 to 7) and GPIOx\_MUXH (for pin 8 to 15) 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 IOMUX structure



## 6.2.8 Multiplexed function configuration

| Mode                                 | IOMC | OM | HDRV                                                                             | ODRV[1:0] | PULL     |
|--------------------------------------|------|----|----------------------------------------------------------------------------------|-----------|----------|
| Push-pull without pull-up/pull-down  | 10   | 0  |                                                                                  |           | 00 or 11 |
| Push-pull with pull-up               | 10   | 0  | 000: output mode, normal sourcing/sinking strength                               |           | 01       |
| Push-pull with pull-down             | 10   | 0  | 001: output mode, large sourcing/sinking strength                                |           | 10       |
| Open-drain without pull-up/pull-down | 10   | 1  | 010: output mode, normal sourcing/sinking strength                               |           | 00 or 11 |
| Open-drain with pull-up              | 10   | 1  | 011: output mode, normal sourcing/sinking strength                               |           | 01       |
| Open-drain with pull-down            | 10   | 1  | 1xx: output mode, maximum sourcing/sinking strength                              |           | 10       |
| Input without pull-up/pull-down      | 10   | x  | Valid for multiplexed function output or bidirectional multiplexed function only |           | 00 or 11 |
| Input with pull-up                   | 10   | x  |                                                                                  |           | 01       |
| 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 an internal pull-up or pull-down.
- In push-pull output mode, output 0/1 according to the peripheral output.
- Get I/O states by reading input data registers.

## 6.2.9 IOMUX input/output

The multiplexed function of each IO port line is configured through the GPIOx\_MUXL (for pin 0 to 7) or GPIOx\_MUXH (for pin 8 to 15) register.

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

| Pin  | MUX0          | MUX1                 | MUX2     | MUX3      | MUX4      | MUX5                 | MUX6                 | MUX7              |
|------|---------------|----------------------|----------|-----------|-----------|----------------------|----------------------|-------------------|
| PA0  |               | TMR2_CH1<br>TMR2_EXT | TMR5_CH1 | TMR8_EXT  | I2C2_SCL  |                      |                      | USART2_CTS        |
| PA1  |               | TMR2_CH2             | TMR5_CH2 |           | I2C2_SDA  | SPI4_MOSI<br>I2S4_SD |                      | USART2_RTS_D<br>E |
| PA2  |               | TMR2_CH3             | TMR5_CH3 | TMR9_CH1  |           |                      |                      | USART2_TX         |
| PA3  |               | TMR2_CH4             | TMR5_CH4 | TMR9_CH2  |           | I2S2_MCK             |                      | USART2_RX         |
| PA4  |               |                      |          |           |           | SPI1_CS<br>I2S1_WS   | SPI3_CS<br>I2S3_WS   | USART2_CK         |
| PA5  |               | TMR2_CH1<br>TMR2_EXT |          | TMR8_CH1C |           | SPI1_SCK<br>I2S1_CK  |                      |                   |
| PA6  |               | TMR1_BRK             | TMR3_CH1 | TMR8_BRK  |           | SPI1_MISO            | I2S2_MCK             | USART3_CTS        |
| PA7  |               | TMR1_CH1C            | TMR3_CH2 | TMR8_CH1C |           | SPI1_MOSI<br>I2S1_SD |                      |                   |
| PA8  | CLKOUT1       | TMR1_CH1             |          |           | I2C3_SCL  |                      |                      | USART1_CK         |
| PA9  |               | TMR1_CH2             |          |           | I2C3_SMBA | SPI2_SCK<br>I2S2_CK  |                      | USART1_TX         |
| PA10 |               | TMR1_CH3             |          |           |           | SPI2_MOSI<br>I2S2_SD | I2S4_MCK             | USART1_RX         |
| PA11 |               | TMR1_CH4             |          |           | I2C2_SCL  | SPI2_CS<br>I2S2_WS   | SPI4_MISO            | USART1_CTS        |
| PA12 |               | TMR1_EXT             |          |           | I2C2_SDA  | SPI2_MISO            |                      | USART1_RTS_D<br>E |
| PA13 | JTMS<br>SWDIO | IR_OUT               |          |           |           |                      | SPI3_MISO            |                   |
| PA14 | JTCK<br>SWCLK |                      |          |           |           |                      | SPI3_MOSI<br>I2S3_SD |                   |
| PA15 | JTDI          | TMR2_CH1<br>TMR2_EXT |          |           |           | SPI1_CS<br>I2S1_WS   | SPI3_CS<br>I2S3_WS   | USART1_TX         |

| Pin  | MUX8      | MUX9      | MUX10     | MUX11                                | MUX12                | MUX13      | MUX14    | MUX15    |
|------|-----------|-----------|-----------|--------------------------------------|----------------------|------------|----------|----------|
| PA0  | UART4_TX  |           |           | EMAC_MII_CRS                         |                      |            |          | EVENTOUT |
| PA1  | UART4_RX  | QSPI1_IO3 |           | EMAC_MII_RX_CLK<br>EMAC_RMII_REF_CLK |                      |            |          | EVENTOUT |
| PA2  |           |           | SDIO2_CK  | EMAC_MDIO                            |                      |            | XMC_D4   | EVENTOUT |
| PA3  |           | QSPI2_IO3 | SDIO2_CMD | EMAC_MII_COL                         |                      |            | XMC_D5   | EVENTOUT |
| PA4  | USART6_TX |           | SDIO2_D4  | SDIO2_D0                             | OTG2_SO_F            | DVP_HSYNC  | XMC_D6   | EVENTOUT |
| PA5  | USART6_RX | QSPI2_IO2 | SDIO2_D5  | SDIO2_D1                             |                      |            | XMC_D7   | EVENTOUT |
| PA6  |           | TMR13_CH1 | QSPI1_IO0 | SDIO2_D2                             | SDIO1_CMD            | DVP_PIXCLK | SDIO2_D6 | EVENTOUT |
| PA7  |           | TMR14_CH1 | QSPI1_IO1 | EMAC_MII_RX_DV<br>EMAC_RMII_CRS_DV   | XMC_SDN_WE           | SDIO2_D3   | SDIO2_D7 | EVENTOUT |
| PA8  | USART2_TX |           | OTG1_SOF  |                                      | SDIO1_D1             |            | XMC_A4   | EVENTOUT |
| PA9  | I2C1_SCL  |           | OTG1_VBUS |                                      | SDIO1_D2             | DVP_D0     |          | EVENTOUT |
| PA10 | I2C1_SDA  |           | OTG1_ID   |                                      |                      | DVP_D1     |          | EVENTOUT |
| PA11 | USART6_TX | CAN1_RX   | OTG1_D-   |                                      |                      | DVP_D2     |          | EVENTOUT |
| PA12 | USART6_RX | CAN1_TX   | OTG1_D+   |                                      |                      | DVP_D3     |          | EVENTOUT |
| PA13 |           |           | OTG1_OE   |                                      |                      |            |          | EVENTOUT |
| PA14 | USART2_TX |           |           |                                      |                      |            |          | EVENTOUT |
| PA15 | USART2_RX | QSPI2_IO1 | QSPI1_IO2 |                                      | XMC_NE2<br>XMC_NCE_3 |            |          | EVENTOUT |

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

| Pin  | MUX0           | MUX1                 | MUX2      | MUX3      | MUX4      | MUX5                 | MUX6                 | MUX7                 |
|------|----------------|----------------------|-----------|-----------|-----------|----------------------|----------------------|----------------------|
| PB0  |                | TMR1_CH2C            | TMR3_CH3  | TMR8_CH2C |           | I2S1_MCK             | USART2_RX            | SPI3_MOSI<br>I2S3_SD |
| PB1  |                | TMR1_CH3C            | TMR3_CH4  | TMR8_CH3C |           |                      | SPI2_SCK<br>I2S2_CK  |                      |
| PB2  |                | TMR2_CH4             | TMR20_CH1 |           | I2C3_SMBA |                      |                      | SPI3_MOSI<br>I2S3_SD |
| PB3  | JTDO<br>SWO    | TMR2_CH2             |           |           | I2C2_SDA  | SPI1_SCK<br>I2S1_CK  | SPI3_SCK<br>I2S3_CK  | USART1_RX            |
| PB4  | JNTRST         |                      | TMR3_CH1  |           | I2C3_SDA  | SPI1_MISO            | SPI3_MISO            | I2S3_SDEXT           |
| PB5  |                |                      | TMR3_CH2  |           | I2C1_SMBA | SPI1_MOSI<br>I2S1_SD | SPI3_MOSI<br>I2S3_SD | USART1_CK            |
| PB6  |                |                      | TMR4_CH1  |           | I2C1_SCL  | I2S1_MCK             | SPI4_CS<br>I2S4_WS   | USART1_TX            |
| PB7  |                |                      | TMR4_CH2  | TMR8_BRK  | I2C1_SDA  |                      | SPI4_SCK<br>I2S4_CK  | USART1_RX            |
| PB8  |                | TMR2_CH1<br>TMR2_EXT | TMR4_CH3  | TMR10_CH1 | I2C1_SCL  |                      | SPI4_MISO            |                      |
| PB9  | IR_OUT         | TMR2_CH2             | TMR4_CH4  | TMR11_CH1 | I2C1_SDA  | SPI2_CS<br>I2S2_WS   | SPI4_MOSI<br>I2S4_SD | I2C2_SDA             |
| PB10 |                | TMR2_CH3             |           |           | I2C2_SCL  | SPI2_SCK<br>I2S2_CK  | I2S3_MCK             | USART3_TX            |
| PB11 |                | TMR2_CH4             | TMR5_CH4  |           | I2C2_SDA  |                      |                      | USART3_RX            |
| PB12 |                | TMR1_BRK             | TMR5_CH1  |           | I2C2_SMBA | SPI2_CS<br>I2S2_WS   | SPI4_CS<br>I2S4_WS   | SPI3_SCK<br>I2S3_CK  |
| PB13 |                | TMR1_CH1C            |           |           | I2C3_SMBA | SPI2_SCK<br>I2S2_CK  | SPI4_SCK<br>I2S4_CK  | I2C3_SCL             |
| PB14 |                | TMR1_CH2C            |           | TMR8_CH2C | I2C3_SDA  | SPI2_MISO            | I2S2_SDEXT           | USART3_RTS_DE        |
| PB15 | ERTC_REFI<br>N | TMR1_CH3C            |           | TMR8_CH3C | I2C3_SCL  | SPI2_MOSI<br>I2S2_SD |                      |                      |

| Pin  | MUX8          | MUX9      | MUX10     | MUX11                             | MUX12       | MUX13     | MUX14    | MUX15    |
|------|---------------|-----------|-----------|-----------------------------------|-------------|-----------|----------|----------|
| PB0  | USART3_CK     | QSPI1_IO0 | QSPI1_IO0 | EMAC_MII_RXD2                     | SDIO1_D1    |           |          | EVENTOUT |
| PB1  | USART3_RTS_DE | QSPI1_SCK | QSPI1_SCK | EMAC_MII_RXD3                     | SDIO1_D2    |           |          | EVENTOUT |
| PB2  |               | QSPI1_SCK |           |                                   | SDIO1_CK    |           |          | EVENTOUT |
| PB3  | UART7_RX      |           | QSPI1_IO3 |                                   |             | DVP_D4    |          | EVENTOUT |
| PB4  | UART7_TX      |           |           |                                   | SDIO1_D0    | DVP_D5    |          | EVENTOUT |
| PB5  | UART5_RX      | CAN2_RX   |           | EMAC_PPS_OUT                      | XMC_SD_CKE1 | DVP_D10   | SDIO1_D3 | EVENTOUT |
| PB6  | UART5_TX      | CAN2_TX   | QSPI1_CS  |                                   | XMC_SD_CS1  | DVP_D5    | SDIO1_D0 | EVENTOUT |
| PB7  |               | QSPI2_IO1 |           |                                   | XMC_NADV    | DVP_VSYNC | SDIO1_D0 | EVENTOUT |
| PB8  | UART5_RX      | CAN1_RX   | QSPI2_CS  | EMAC_MII_RXD3                     | SDIO1_D4    | DVP_D6    |          | EVENTOUT |
| PB9  | UART5_TX      | CAN1_TX   | QSPI1_CS  |                                   | SDIO1_D5    | DVP_D7    |          | EVENTOUT |
| PB10 |               | QSPI1_CS  | QSPI1_IO1 | EMAC_MII_RX_ER                    | SDIO1_D7    |           | XMC_NOE  | EVENTOUT |
| PB11 |               |           | QSPI1_IO0 | EMAC_MII_TX_EN<br>EMAC_RMII_TX_EN |             |           |          | EVENTOUT |
| PB12 | USART3_CK     | CAN2_RX   |           | EMAC_MII_RXD0<br>EMAC_RMII_RXD0   | OTG2_ID     |           | XMC_D13  | EVENTOUT |
| PB13 | USART3_CTS    | CAN2_TX   |           | EMAC_MII_RXD1<br>EMAC_RMII_RXD1   | OTG2_VBUS   |           |          | EVENTOUT |
| PB14 |               | TMR12_CH1 |           |                                   | OTG2_D-     | SDIO1_D6  | XMC_D0   | EVENTOUT |
| PB15 |               | TMR12_CH2 |           |                                   | OTG2_D+     | SDIO1_CK  |          | EVENTOUT |

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

| Pin  | MUX0    | MUX1 | MUX2      | MUX3      | MUX4      | MUX5                    | MUX6                    | MUX7                    |
|------|---------|------|-----------|-----------|-----------|-------------------------|-------------------------|-------------------------|
| PC0  |         |      |           |           | I2C3_SCL  |                         |                         |                         |
| PC1  |         |      |           |           | I2C3_SDA  | SPI3_MOSI<br>I2S3_SDEXT |                         | SPI2_MOSI<br>I2S2_SDEXT |
| PC2  |         |      | TMR20_CH2 |           |           | SPI2_MISO               | I2S2_SDEXT              |                         |
| PC3  |         |      |           |           |           | SPI2_MOSI<br>I2S2_SDEXT |                         |                         |
| PC4  |         |      |           | TMR9_CH1  |           | I2S1_MCK                |                         | USART3_TX               |
| PC5  |         |      |           | TMR9_CH2  | I2C1_SMBA |                         |                         | USART3_RX               |
| PC6  |         |      | TMR3_CH1  | TMR8_CH1  | I2C1_SCL  | I2S2_MCK                |                         |                         |
| PC7  |         |      | TMR3_CH2  | TMR8_CH2  | I2C1_SDA  | SPI2_SCK<br>I2S2_CK     | I2S3_MCK                |                         |
| PC8  |         |      | TMR3_CH3  | TMR8_CH3  |           | I2S4_MCK                | TMR20_CH3               | UART8_TX                |
| PC9  | CLKOUT2 |      | TMR3_CH4  | TMR8_CH4  | I2C3_SDA  |                         |                         | UART8_RX                |
| PC10 |         |      | TMR5_CH2  |           |           |                         | SPI3_SCK<br>I2S3_CK     | USART3_TX               |
| PC11 |         |      | TMR5_CH3  |           |           | I2S3_SDEXT              | SPI3_MISO               | USART3_RX               |
| PC12 |         |      |           | TMR11_CH1 | I2C2_SDA  |                         | SPI3_MOSI<br>I2S3_SDEXT | USART3_CK               |
| PC13 |         |      |           |           |           |                         |                         |                         |
| PC14 |         |      |           |           |           |                         |                         |                         |
| PC15 |         |      |           |           |           |                         |                         |                         |

| Pin  | MUX8      | MUX9      | MUX10     | MUX11                            | MUX12      | MUX13     | MUX14   | MUX15    |
|------|-----------|-----------|-----------|----------------------------------|------------|-----------|---------|----------|
| PC0  | UART7_TX  |           | SDIO2_D0  |                                  | XMC_SDNWE  |           |         | EVENTOUT |
| PC1  | UART7_RX  |           | SDIO2_D1  | EMAC_MDC                         |            |           |         | EVENTOUT |
| PC2  | UART8_TX  |           | SDIO2_D2  | EMAC_MII_TXD2                    | XMC_SDCS0  |           | XMC_NWE | EVENTOUT |
| PC3  | UART8_RX  | QSPI2_IO1 | SDIO2_D3  | EMAC_MII_TX_C_LK                 | XMC_SDCKE0 |           | XMC_A0  | EVENTOUT |
| PC4  |           |           | QSPI1_IO2 | EMAC_MII_RXD0<br>EMAC_RMII_RX_D0 | XMC_SDCS0  | SDIO2_CK  | XMC_NE4 | EVENTOUT |
| PC5  |           |           | QSPI1_IO3 | EMAC_MII_RXD1<br>EMAC_RMII_RX_D1 | XMC_SDCKE0 | SDIO2_CMD | XMC_NOE | EVENTOUT |
| PC6  | USART6_TX |           | XMC_A0    |                                  | SDIO1_D6   | DVP_D0    | XMC_D1  | EVENTOUT |
| PC7  | USART6_RX |           | XMC_A1    |                                  | SDIO1_D7   | DVP_D1    |         | EVENTOUT |
| PC8  | USART6_CK | QSPI1_IO2 | XMC_A2    |                                  | SDIO1_D0   | DVP_D2    |         | EVENTOUT |
| PC9  |           | QSPI1_IO0 | XMC_A3    | OTG2_OE                          | SDIO1_D1   | DVP_D3    |         | EVENTOUT |
| PC10 | UART4_TX  | QSPI1_IO1 |           |                                  | SDIO1_D2   | DVP_D8    |         | EVENTOUT |
| PC11 | UART4_RX  | QSPI1_CS  |           |                                  | SDIO1_D3   | DVP_D4    | XMC_D2  | EVENTOUT |
| PC12 | UART5_TX  |           |           |                                  | SDIO1_CK   | DVP_D9    | XMC_D3  | EVENTOUT |
| PC13 |           |           |           |                                  |            |           |         | EVENTOUT |
| PC14 |           |           |           |                                  |            |           |         | EVENTOUT |
| PC15 |           |           |           |                                  |            |           |         | EVENTOUT |

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

| Pin  | MUX0 | MUX1 | MUX2     | MUX3 | MUX4      | MUX5                    | MUX6                    | MUX7               |
|------|------|------|----------|------|-----------|-------------------------|-------------------------|--------------------|
| PD0  |      |      |          |      |           | SPI4_MISO               | SPI2_CS<br>I2S3_SDEXT   | SPI2_CS<br>I2S2_WS |
| PD1  |      |      |          |      |           |                         | SPI2_SCK<br>I2S2_CK     | SPI2_CS<br>I2S2_WS |
| PD2  |      |      | TMR3_EXT |      |           |                         |                         | USART3_RTS_DE      |
| PD3  |      |      |          |      |           | SPI2_SCK<br>I2S2_CK     | SPI2_MISO               | USART2_CTS         |
| PD4  |      |      |          |      |           |                         | SPI2_MOSI<br>I2S2_SDEXT | USART2_RTS_DE      |
| PD5  |      |      |          |      |           |                         |                         | USART2_TX          |
| PD6  |      |      |          |      |           | SPI3_MOSI<br>I2S3_SDEXT |                         | USART2_RX          |
| PD7  |      |      |          |      |           |                         |                         | USART2_CK          |
| PD8  |      |      |          |      |           |                         |                         | USART3_TX          |
| PD9  |      |      |          |      |           |                         |                         | USART3_RX          |
| PD10 |      |      |          |      |           |                         |                         | USART3_CK          |
| PD11 |      |      |          |      | I2C2_SMBA |                         |                         | USART3_CTS         |
| PD12 |      |      | TMR4_CH1 |      | I2C2_SCL  |                         |                         | USART3_RTS_DE      |
| PD13 |      |      | TMR4_CH2 |      | I2C2_SDA  |                         |                         |                    |
| PD14 |      |      | TMR4_CH3 |      | I2C3_SCL  |                         |                         |                    |
| PD15 |      |      | TMR4_CH4 |      | I2C3_SDA  |                         |                         |                    |

| Pin  | MUX8     | MUX9      | MUX10                | MUX11                              | MUX12               | MUX13   | MUX14   | MUX15    |
|------|----------|-----------|----------------------|------------------------------------|---------------------|---------|---------|----------|
| PD0  |          | CAN1_RX   | XMC_A5               |                                    | XMC_D2              |         |         | EVENTOUT |
| PD1  |          | CAN1_TX   | XMC_A6               |                                    | XMC_D3              |         |         | EVENTOUT |
| PD2  | UART5_RX |           | XMC_A7               |                                    | SDIO1_CMD           | DVP_D11 | XMC_NWE | EVENTOUT |
| PD3  |          | QSPI1_SCK | XMC_A8               |                                    | XMC_CLK             | DVP_D5  |         | EVENTOUT |
| PD4  |          |           | XMC_A9               |                                    | XMC_NOE             |         |         | EVENTOUT |
| PD5  |          |           | XMC_A10              |                                    | XMC_NWE             |         |         | EVENTOUT |
| PD6  |          |           | XMC_A11              |                                    | XMC_NWAIT           | DVP_D10 |         | EVENTOUT |
| PD7  |          |           | XMC_A12              |                                    | XMC_NE1<br>XMC_NCE2 |         |         | EVENTOUT |
| PD8  |          |           |                      | EMAC_MII_RX_DV<br>EMAC_RMII_CRS_DV | XMC_D13             |         |         | EVENTOUT |
| PD9  |          |           |                      | EMAC_MII_RXD0<br>EMAC_RMII_RXD0    | XMC_D14             |         |         | EVENTOUT |
| PD10 |          |           |                      | EMAC_MII_RXD1<br>EMAC_RMII_RXD1    | XMC_D15             |         |         | EVENTOUT |
| PD11 |          | QSPI1_IO0 | XMC_A14<br>XMC_SDBA0 | EMAC_MII_RXD2                      | XMC_A16<br>XMC_CLE  |         |         | EVENTOUT |
| PD12 |          | QSPI1_IO1 | XMC_A15<br>XMC_SDBA1 | EMAC_MII_RXD3                      | XMC_A17<br>XMC_ALE  |         |         | EVENTOUT |
| PD13 | UART8_TX | QSPI1_IO3 | XMC_SD_CLK           |                                    | XMC_A18             |         |         | EVENTOUT |
| PD14 | UART8_RX |           |                      |                                    | XMC_D0              |         |         | EVENTOUT |
| PD15 |          |           |                      |                                    | XMC_D1              |         |         | EVENTOUT |

Table 6-5 Port E multiplexed function configuration with GPIOE\_MUX\* register

| Pin  | MUX0    | MUX1      | MUX2     | MUX3     | MUX4                    | MUX5                    | MUX6       | MUX7     |
|------|---------|-----------|----------|----------|-------------------------|-------------------------|------------|----------|
| PE0  |         |           | TMR4_EXT |          |                         |                         | TMR20_EXT  |          |
| PE1  |         | TMR1_CH2C |          |          |                         |                         | TMR20_CH4  |          |
| PE2  |         |           | TMR3_EXT |          |                         | SPI4_SCK<br>I2S4_CK     | TMR20_CH1  |          |
| PE3  |         |           | TMR3_CH1 |          |                         |                         | TMR20_CH2  |          |
| PE4  | CLKOUT1 |           | TMR3_CH2 |          |                         | SPI4_CS<br>I2S4_WS      | TMR20_CH1C |          |
| PE5  |         |           | TMR3_CH3 | TMR9_CH1 |                         | SPI4_MISO               | TMR20_CH2C |          |
| PE6  |         |           | TMR3_CH4 | TMR9_CH2 |                         | SPI4_MOSI<br>I2S4_SDEXT | TMR20_CH3C |          |
| PE7  |         | TMR1_EXT  |          |          |                         |                         |            |          |
| PE8  |         | TMR1_CH1C |          |          |                         |                         |            | UART4_TX |
| PE9  |         | TMR1_CH1  |          |          |                         |                         |            | UART4_RX |
| PE10 |         | TMR1_CH2C |          |          |                         |                         |            |          |
| PE11 |         | TMR1_CH2  |          |          |                         | SPI4_CS<br>I2S4_WS      |            |          |
| PE12 |         | TMR1_CH3C |          |          | SPI1_CS<br>I2S1_WS      | SPI4_SCK<br>I2S4_CK     |            |          |
| PE13 |         | TMR1_CH3  |          |          | SPI1_SCK<br>I2S1_CK     | SPI4_MISO               |            |          |
| PE14 |         | TMR1_CH4  |          |          | SPI1_MISO               | SPI4_MOSI<br>I2S4_SDEXT |            |          |
| PE15 |         | TMR1_BRK  |          |          | SPI1_MOSI<br>I2S1_SDEXT |                         |            |          |

| Pin  | MUX8     | MUX9      | MUX10      | MUX11         | MUX12              | MUX13  | MUX14 | MUX15    |
|------|----------|-----------|------------|---------------|--------------------|--------|-------|----------|
| PE0  | UART8_RX |           |            |               | XMC_LB/XM_C_SDDQML | DVP_D2 |       | EVENTOUT |
| PE1  | UART8_TX |           |            |               | XMC_UB/XM_C_SDDQMH | DVP_D3 |       | EVENTOUT |
| PE2  |          | QSPI1_IO2 | XMC_SDNCAS | EMAC_MII_TXD3 | XMC_A23            |        |       | EVENTOUT |
| PE3  |          |           |            |               | XMC_A19            | DVP_D9 |       | EVENTOUT |
| PE4  |          |           |            |               | XMC_A20            | DVP_D4 |       | EVENTOUT |
| PE5  |          |           |            |               | XMC_A21            | DVP_D6 |       | EVENTOUT |
| PE6  |          |           | XMC_SDNRAS |               | XMC_A22            | DVP_D7 |       | EVENTOUT |
| PE7  | UART7_RX |           | QSPI2_IO0  |               | XMC_D4             |        |       | EVENTOUT |
| PE8  | UART7_TX |           | QSPI2_IO1  |               | XMC_D5             |        |       | EVENTOUT |
| PE9  |          |           | QSPI2_IO2  |               | XMC_D6             |        |       | EVENTOUT |
| PE10 | UART5_TX |           | QSPI2_IO3  |               | XMC_D7             |        |       | EVENTOUT |
| PE11 | UART5_RX |           |            |               | XMC_D8             |        |       | EVENTOUT |
| PE12 |          |           |            |               | XMC_D9             |        |       | EVENTOUT |
| PE13 |          |           |            |               | XMC_D10            |        |       | EVENTOUT |
| PE14 |          |           |            |               | XMC_D11            |        |       | EVENTOUT |
| PE15 |          |           |            |               | XMC_D12            |        |       | EVENTOUT |

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

| Pin  | MUX0 | MUX1     | MUX2       | MUX3      | MUX4      | MUX5 | MUX6 | MUX7 |
|------|------|----------|------------|-----------|-----------|------|------|------|
| PF0  |      |          |            |           | I2C2_SDA  |      |      |      |
| PF1  |      |          |            |           | I2C2_SCL  |      |      |      |
| PF2  |      |          | TMR20_CH3  |           | I2C2_SMBA |      |      |      |
| PF3  |      |          | TMR20_CH4  |           |           |      |      |      |
| PF4  |      |          | TMR20_CH1C |           |           |      |      |      |
| PF5  |      |          | TMR20_CH2C |           |           |      |      |      |
| PF6  |      |          | TMR20_CH4  | TMR10_CH1 |           |      |      |      |
| PF7  |      |          | TMR20_BRK  | TMR11_CH1 |           |      |      |      |
| PF8  |      |          |            |           |           |      |      |      |
| PF9  |      |          | TMR20_BRK  |           |           |      |      |      |
| PF10 |      | TMR1_EXT | TMR5_CH4   |           |           |      |      |      |
| PF11 |      |          | TMR20_EXT  | TMR8_EXT  |           |      |      |      |
| PF12 |      |          | TMR20_CH1  | TMR8_BRK  |           |      |      |      |
| PF13 |      |          | TMR20_CH2  |           | I2C3_SMBA |      |      |      |
| PF14 |      |          | TMR20_CH3  |           | I2C3_SCL  |      |      |      |
| PF15 |      |          | TMR20_CH4  |           | I2C3_SDA  |      |      |      |

| Pin  | MUX8     | MUX9      | MUX10          | MUX11 | MUX12      | MUX13   | MUX14 | MUX15    |
|------|----------|-----------|----------------|-------|------------|---------|-------|----------|
| PF0  |          |           |                |       | XMC_A0     |         |       | EVENTOUT |
| PF1  |          |           |                |       | XMC_A1     |         |       | EVENTOUT |
| PF2  |          |           |                |       | XMC_A2     |         |       | EVENTOUT |
| PF3  |          |           |                |       | XMC_A3     |         |       | EVENTOUT |
| PF4  |          |           |                |       | XMC_A4     |         |       | EVENTOUT |
| PF5  |          |           |                |       | XMC_A5     |         |       | EVENTOUT |
| PF6  | UART7_RX | QSPI1_IO3 |                |       | XMC_NIORD  |         |       | EVENTOUT |
| PF7  | UART7_TX | QSPI1_IO2 |                |       | XMC_NREG   |         |       | EVENTOUT |
| PF8  |          | TMR13_CH1 | QSPI1_IO0      |       | XMC_NIOWR  |         |       | EVENTOUT |
| PF9  |          | TMR14_CH1 | QSPI1_MOSI_IO1 |       | XMC_CD     |         |       | EVENTOUT |
| PF10 |          | QSPI1_SCK |                |       | XMC_INTR   | DVP_D11 |       | EVENTOUT |
| PF11 |          |           |                |       | XMC_SDNRAS | DVP_D12 |       | EVENTOUT |
| PF12 |          |           |                |       | XMC_A6     |         |       | EVENTOUT |
| PF13 |          |           |                |       | XMC_A7     |         |       | EVENTOUT |
| PF14 |          |           |                |       | XMC_A8     |         |       | EVENTOUT |
| PF15 |          |           |                |       | XMC_A9     |         |       | EVENTOUT |

Table 6-7 Port G multiplexed function configuration with GPIOG\_MUX\* register

| Pin  | MUX0 | MUX1 | MUX2       | MUX3 | MUX4 | MUX5                    | MUX6                    | MUX7 |
|------|------|------|------------|------|------|-------------------------|-------------------------|------|
| PG0  |      |      | TMR20_CH1C |      |      | SPI1_MISO               |                         |      |
| PG1  |      |      | TMR20_CH2C |      |      | SPI1_MOSI<br>I2S1_SDEXT |                         |      |
| PG2  |      |      | TMR20_CH3C |      |      |                         |                         |      |
| PG3  |      |      | TMR20_BRK  |      |      |                         |                         |      |
| PG4  |      |      |            |      |      |                         |                         |      |
| PG5  |      |      | TMR20_EXT  |      |      |                         |                         |      |
| PG6  |      |      |            |      |      |                         |                         |      |
| PG7  |      |      |            |      |      |                         |                         |      |
| PG8  |      |      |            |      |      | QSPI2_CS                |                         |      |
| PG9  |      |      |            |      |      |                         |                         |      |
| PG10 |      |      |            |      |      | QSPI2_IO2               |                         |      |
| PG11 |      |      |            |      |      | QSPI2_IO3               | SPI4_SCK<br>I2S4_CK     |      |
| PG12 |      |      |            |      |      | QSPI2_IO1               | SPI4_MISO               |      |
| PG13 |      |      |            |      |      | QSPI2_SCK               | SPI4_MOSI<br>I2S4_SDEXT |      |
| PG14 |      |      |            |      |      | QSPI2_IO0               | SPI4_CS<br>I2S4_WS      |      |
| PG15 |      |      |            |      |      |                         |                         |      |

| Pin  | MUX8          | MUX9      | MUX10    | MUX11                             | MUX12                 | MUX13         | MUX1<br>4 | MUX15    |
|------|---------------|-----------|----------|-----------------------------------|-----------------------|---------------|-----------|----------|
| PG0  |               | CAN1_RX   |          |                                   | XMC_A10               |               |           | EVENTOUT |
| PG1  |               | CAN1_TX   |          |                                   | XMC_A11               |               |           | EVENTOUT |
| PG2  |               |           |          |                                   | XMC_A12               |               |           | EVENTOUT |
| PG3  |               |           |          |                                   | XMC_A13               |               |           | EVENTOUT |
| PG4  |               |           |          |                                   | XMC_A14<br>XMC_SDBA0  |               |           | EVENTOUT |
| PG5  |               |           |          |                                   | XMC_A15<br>XMC_SDBA1  |               |           | EVENTOUT |
| PG6  |               |           | QSPI1_CS |                                   | XMC_INT2              | DVP_D12       |           | EVENTOUT |
| PG7  | USART6_CK     |           |          |                                   | XMC_INT3              | DVP_D13       |           | EVENTOUT |
| PG8  | USART6_RTS_DE |           |          | EMAC_PPS_OUT                      | XMC_SDCLK             |               |           | EVENTOUT |
| PG9  | USART6_RX     | QSPI1_IO2 |          |                                   | XMC_NE2<br>XMC_NCE3   | DVP_VSY<br>NC |           | EVENTOUT |
| PG10 |               |           |          |                                   | XMC_NE3<br>XMC_NCE4_1 | DVP_D2        |           | EVENTOUT |
| PG11 |               | CAN2_RX   |          | EMAC_MII_TX_EN<br>EMAC_RMII_TX_EN | XMC_NCE4_2            | DVP_D3        |           | EVENTOUT |
| PG12 | USART6_RTS_DE | CAN2_TX   |          |                                   | XMC_NE4               |               |           | EVENTOUT |
| PG13 | USART6_CTS    |           |          | EMAC_MII_TXD0<br>EMAC_RMII_TXD0   | XMC_A24               |               |           | EVENTOUT |
| PG14 | USART6_TX     | QSPI1_IO3 |          | EMAC_MII_TXD1<br>EMAC_RMII_TXD1   | XMC_A25               |               |           | EVENTOUT |
| PG15 | USART6_CTS    |           |          |                                   | XMC_SDNCAS            | DVP_D13       |           | EVENTOUT |

Table 6-8 Port H multiplexed function configuration with GPIOH\_MUX\* register

| Pin | MUX0 | MUX1 | MUX2     | MUX3 | MUX4     | MUX5 | MUX6 | MUX7 |
|-----|------|------|----------|------|----------|------|------|------|
| PH0 |      |      |          |      | I2C1_SDA |      |      |      |
| PH1 |      |      |          |      | I2C1_SCL |      |      |      |
| PH2 |      |      | TMR5_CH1 |      | I2C2_SCL |      |      |      |
| PH3 |      |      | TMR5_CH2 |      | I2C2_SDA |      |      |      |

  

| Pin | MUX8     | MUX9 | MUX10     | MUX11 | MUX12 | MUX13 | MUX14 | MUX15    |
|-----|----------|------|-----------|-------|-------|-------|-------|----------|
| PH0 |          |      |           |       |       |       |       | EVENTOUT |
| PH1 |          |      |           |       |       |       |       | EVENTOUT |
| PH2 | UART4_RX |      | QSPI1_IO0 |       |       |       |       | EVENTOUT |
| PH3 | UART4_TX |      | QSPI1_IO1 |       |       |       |       | EVENTOUT |

Note: EVENTOUT is the Cortex®-M TXEV signal.

## 6.2.10 Peripheral MUX function configuration

IOMUX function configuration as follows:

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

## 6.2.11 IOMUX map 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-9 Pins owned by hardware

| Pin  | Enable bit                                                                     | Description                                           |
|------|--------------------------------------------------------------------------------|-------------------------------------------------------|
| PA0  | PWC_CTRLSTS[8]=1<br>(ERTC_CTRL[11]=1&<br>ERTC_TAMP[17]=1)                      | Once enabled, PA0 pin acts as WKUP1 function of PWC.  |
| PA0  | (ERTC_CTRL[0]=1&<br>ERTC_TAMP[16]=1) <br>(ERTC_TAMP[3]=1)                      | Once enabled, PA0 pin is used as TAMPER2_BPR.         |
| PA4  | DAC_CTRL[2]=1                                                                  | Once enabled, PA4 pin acts as DAC1 analog channel.    |
| PA5  | DAC_CTRL[18]=1                                                                 | Once enabled, PA5 pin acts as DAC2 analog channel.    |
| PC13 | PWC_CTRLSTS[9] = 1<br>(ERTC_CTRL[23]=1) <br>(ERTC_CTRL[22:21]!=0))             | Once enabled, PC13 pin acts as WKUP2 function of PWC. |
| PC13 | (ERTC_CTRL[11]=1&<br>ERTC_TAMP[17]=0) <br>(ERTC_TAMP[0]=1&<br>ERTC_TAMP[16]=0) | Once enabled, PC13 pin acts as RTC channel.           |
| PC14 | CRM_BPDC[0]=1                                                                  | Once enabled, PC14 pin acts as LEXT channel.          |
| PC15 | CRM_BPDC[0]=1 &<br>CRM_BPDC[2]=0                                               | Once enabled, PC15 pin acts as LEXT channel.          |
| PH0  | CRM_CTRL[16]=1                                                                 | Once enabled, PH0 pin acts as HEXT channel.           |
| PH1  | CRM_CTRL[16]=1&<br>CRM_CTRL[18]=0                                              | Once enabled, PH1 pin acts as HEXT channel.           |

*Note: Either PA0 or PC13 cannot be used as TAMPER\_BPR and 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

Table 6-10 lists GPIO register map and their reset values. These peripheral registers must be accessed by bytes (8 bits), half-words (16 bits) or words (32 bits).

Table 6-10 GPIO register map and reset values

| Register              | Offset | Reset value                   |
|-----------------------|--------|-------------------------------|
| GPIOA_CFGR            | 0x00   | 0xA800 0000                   |
| GPIOx_CFGR(x =B,C,F)  | 0x00   | 0x0000 0280(B)<br>0x0000 0000 |
| GPIOx_OMODER          | 0x04   | 0x0000 0000                   |
| GPIOx_ODRVR           | 0x08   | 0x0000 00C0(B)<br>0x0000 0000 |
| GPIOA_PULL            | 0x0C   | 0x6400 0000(A)                |
| GPIOx_PULL(x = B,C,F) | 0x0C   | 0x0000 0100(B)<br>0x0000 0000 |
| 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_HDRV            | 0x3C   | 0x0000 0000                   |

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

Address offset: 0x00

Reset values: 0xa8000000 for port A, 0x0000 0280 for port B, 0x00000000 for other ports

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

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

| Bit        | Name     | Reset value | Type | Description                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Always 0.                                                                                                                                        |
| Bit 15: 0  | OM       | 0x0000      | rw   | GPIOx output mode configuration<br>These field is used to configure the output mode of the GPIOx:<br>0: Push-pull (reset state)<br>1: Open-drain |

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

Address offset: 0x08

Reset values: 0x0000 00C0 for port B 0x00000000 for other ports

| Bit          | Name  | Reset value | Type | Description                                                                                                                                                                                                               |
|--------------|-------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 2y+1: 2y | ODRVy | 0x0000 0000 | rw   | GPIOx drive capability (y=0...15)<br>This field is used to configure the IO port drive capability.<br>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..H)

Address offset: 0x0C

Reset values: 0x6400 0000 for port A, 0x0000 0100 for port B, 0x00000000 for other ports

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

### 6.3.5 GPIO input register (GPIOx\_IDH) (x=A..H)

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

### 6.3.6 GPIO output register (GPIOx\_ODH) (x=A..H)

| Bit        | Name     | Reset value | Type | Description                                                                                                               |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                |
| 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..H)

| 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.<br>0: No action to the corresponding ODT bits<br>1: Set the corresponding ODT bits         |

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

| 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<br/>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<br/>Each bit corresponds to an I/O port.<br/>0: No effect.<br/>1: Write protect</p>                                                                                                                                                                                                                                                              |

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

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)<br/>This field is used to configure multiplexed function IOs.</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..H)

| 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 IOs<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..H)

| 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 huge current control register (GPIOx\_HDRV) (x=A..E)

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

# 7 System configuration controller (SCFG)

## 7.1 Introduction

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

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

## 7.2 IOMUX registers

Table 7-1 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 values

| 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: 12 | Reserved    | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 11: 10 | SWAP_XMC    | 0x0         | rw   | XMC address mapping swap<br>00: No XMC address mapping swap<br>01: SDRAM addresses are mapped at 0x6000 0000 and 0x7000 0000. NOR/PSRAM /SRAM/NAND2 memory addresses are mapped at 0xC000 0000 and 0xD000 0000.<br>10: QSPI2 memory addresses are mapped at 0x8000 0000. NAND3 memory is mapped at 0xB000 0000.<br>11: SDRAM memory addresses are mapped at 0x6000 0000 and 0x7000 0000. NOR/PSRAM /SRAM/NAND2 memory addresses are mapped at 0xC000 00000 and 0xD000 0000. QSPI2 memory addresses are mapped at 0x8000 0000. NAND3 memory is mapped at 0xB000 0000. |
| Bit 9: 8   | Reserved    | 0x0         | 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: 3   | Reserved    | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 2: 0   | MEM_MAP_SEL | 0xX         | rw   | Memory address mapping selection<br>This field defines the memory address mapping at 0x0000 0000. After reset, the reset value of this field is the same                                                                                                                                                                                                                                                                                                                                                                                                             |

as that of the BOOT0 and BOOT1 pins. After changing this field, the user can decide which of the following memory to be mapped at 0x0000 0000.

- 000: Main Flash memory mapped at 0x0000 0000
- 001: Boot memory mapped at 0x0000 0000
- 010: XMC BANK1 mapped at 0x0000 0000
- 011: Embedded SRAM mapped at 0x0000 0000
- 100: XMC SDRAM BANK1 mapped at 0x0000 0000
- Others: Reserved.

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

| Bit        | Name         | Reset value | Type | Description                                                                                                                                                             |
|------------|--------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved     | 0x00        | resd | Kept at its default value.                                                                                                                                              |
| Bit 23     | MII_RMII_SEL | 0x0         | rw   | MII or RMII selection<br>This bit is used to select the Ethernet MII or RMII interface.<br>0: MII<br>1: RMII<br><small>Note: This bit applies to AT32F437 only.</small> |
| Bit 22: 0  | Reserved     | 0x00000X    | resd | Kept at its default value.                                                                                                                                              |

## 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   | 0x0000      | rw   | EXINT3 input source configuration<br>These bits are used to select the input source for the EXINT3 external interrupt.<br>0000: GPIOA pin3<br>0001: GPIOB pin3<br>0010: GPIOC pin3<br>0011: GPIOD pin3<br>0100: GPIOE pin3<br>0101: GPIOF pin3<br>0110: GPIOG pin3<br>0111: GPIOH pin3<br>Others: Reserved |
| Bit 11: 8  | EXINT2   | 0x0000      | rw   | EXINT2 input source configuration<br>These bits are used to select the input source for the EXINT2 external interrupt.<br>0000: GPIOA pin2<br>0001: GPIOB pin2<br>0010: GPIOC pin2<br>0011: GPIOD pin2<br>0100: GPIOE pin2<br>0101: GPIOF pin2<br>0110: GPIOG pin2<br>0111: GPIOH pin2<br>Others: Reserved |
| Bit 7: 4   | EXINT1   | 0x0000      | rw   | EXINT1 input source configuration<br>These bits are used to select the input source for the EXINT1 external interrupt.                                                                                                                                                                                     |

---

|          |        |        |    |                                                                                                                                                                                                                                                                                                                                |
|----------|--------|--------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |        |    | 0000: GPIOA pin1<br>0001: GPIOB pin1<br>0010: GPIOC pin1<br>0011: GPIOD pin1<br>0100: GPIOE pin1<br>0101: GPIOF pin1<br>0110: GPIOG pin1<br>0111: GPIOH pin1<br>Others: Reserved                                                                                                                                               |
| Bit 3: 0 | EXINT0 | 0x0000 | rw | <p>EXINT0 input source configuration<br/>These bits are used to select the input source for the EXINT0 external interrupt.</p> <p>0000: GPIOA pin0<br/>0001: GPIOB pin0<br/>0010: GPIOC pin0<br/>0011: GPIOD pin0<br/>0100: GPIOE pin0<br/>0101: GPIOF pin0<br/>0110: GPIOG pin0<br/>0111: GPIOH pin0<br/>Others: Reserved</p> |

---

## 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   | 0x0000      | rw   | <p>EXINT7 input source configuration<br/>These bits are used to select the input source for the EXINT7 external interrupt.</p> <p>0000: GPIOA pin7<br/>0001: GPIOB pin7<br/>0010: GPIOC pin7<br/>0011: GPIOD pin7<br/>0100: GPIOE pin7<br/>0101: GPIOF pin7<br/>0110: GPIOG pin7<br/>0111: GPIOH pin7<br/>Others: Reserved</p> |
| Bit 11: 8  | EXINT6   | 0x0000      | rw   | <p>EXINT6 input source configuration<br/>These bits are used to select the input source for the EXINT6 external interrupt.</p> <p>0000: GPIOA pin6<br/>0001: GPIOB pin6<br/>0010: GPIOC pin6<br/>0011: GPIOD pin6<br/>0100: GPIOE pin6<br/>0101: GPIOF pin6<br/>0110: GPIOG pin6</p>                                           |

---

|          |        |        |    |                                                                                                                                                                                                                                                                                                            |
|----------|--------|--------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |        |    | 0111: GPIOH pin6<br>Others: Reserved                                                                                                                                                                                                                                                                       |
| Bit 7: 4 | EXINT5 | 0x0000 | rw | EXINT5 input source configuration<br>These bits are used to select the input source for the EXINT5 external interrupt.<br>0000: GPIOA pin5<br>0001: GPIOB pin5<br>0010: GPIOC pin5<br>0011: GPIOD pin5<br>0100: GPIOE pin5<br>0101: GPIOF pin5<br>0110: GPIOG pin5<br>0111: GPIOH pin5<br>Others: Reserved |
| Bit 3: 0 | EXINT4 | 0x0000 | rw | EXINT4 input source configuration<br>These bits are used to select the input source for the EXINT4 external interrupt.<br>0000: GPIOA pin4<br>0001: GPIOB pin4<br>0010: GPIOC pin4<br>0011: GPIOD pin4<br>0100: GPIOE pin4<br>0101: GPIOF pin4<br>0110: GPIOG pin4<br>0111: GPIOH pin4<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  | 0x0000      | rw   | EXINT11 input source configuration<br>These bits are used to select the input source for the EXINT11 external interrupt.<br>0000: GPIOA pin11<br>0001: GPIOB pin11<br>0010: GPIOC pin11<br>0011: GPIOD pin11<br>0100: GPIOE pin11<br>0101: GPIOF pin11<br>0110: GPIOG pin11<br>0111: GPIOH pin11<br>Others: Reserved |
| Bit 11: 8  | EXINT10  | 0x0000      | rw   | EXINT10 input source configuration<br>These bits are used to select the input source for the EXINT10 external interrupt.<br>0000: GPIOA pin10<br>0001: GPIOB pin10                                                                                                                                                   |

|          |        |        |    |                                                                                                                                                                                                                                                                                                            |
|----------|--------|--------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |        |    | 0010: GPIOC pin10<br>0011: GPIOD pin10<br>0100: GPIOE pin10<br>0101: GPIOF pin10<br>0110: GPIOG pin10<br>0111: GPIOH pin10<br>Others: Reserved                                                                                                                                                             |
| Bit 7: 4 | EXINT9 | 0x0000 | rw | EXINT9 input source configuration<br>These bits are used to select the input source for the EXINT9 external interrupt.<br>0000: GPIOA pin9<br>0001: GPIOB pin9<br>0010: GPIOC pin9<br>0011: GPIOD pin9<br>0100: GPIOE pin9<br>0101: GPIOF pin9<br>0110: GPIOG pin9<br>0111: GPIOH pin9<br>Others: Reserved |
| Bit 3: 0 | EXINT8 | 0x0000 | rw | EXINT8 input source configuration<br>These bits are used to select the input source for the EXINT8 external interrupt.<br>0000: GPIOA pin8<br>0001: GPIOB pin8<br>0010: GPIOC pin8<br>0011: GPIOD pin8<br>0100: GPIOE pin8<br>0101: GPIOF pin8<br>0110: GPIOG pin8<br>0111: GPIOH pin8<br>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  | 0x0000      | rw   | EXINT15 input source configuration<br>These bits are used to select the input source for the EXINT15 external interrupt.<br>0000: GPIOA pin15<br>0001: GPIOB pin15<br>0010: GPIOC pin15<br>0011: GPIOD pin15<br>0100: GPIOE pin15<br>0101: GPIOF pin15<br>0110: GPIOG pin15<br>0111: GPIOH pin15<br>Others: Reserved |

|           |         |        |    |                                                                                                                                                                                                                                                                                                                      |
|-----------|---------|--------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |         |        |    | EXINT14 input source configuration<br>These bits are used to select the input source for the EXINT14 external interrupt.<br>0000: GPIOA pin14<br>0001: GPIOB pin14<br>0010: GPIOC pin14<br>0011: GPIOD pin14<br>0100: GPIOE pin14<br>0101: GPIOF pin14<br>0110: GPIOG pin14<br>0111: GPIOH pin14<br>Others: Reserved |
| Bit 11: 8 | EXINT14 | 0x0000 | rw | EXINT13 input source configuration<br>These bits are used to select the input source for the EXINT13 external interrupt.<br>0000: GPIOA pin13<br>0001: GPIOB pin13<br>0010: GPIOC pin13<br>0011: GPIOD pin13<br>0100: GPIOE pin13<br>0101: GPIOF pin13<br>0110: GPIOG pin13<br>0111: GPIOH pin13<br>Others: Reserved |
| Bit 7:4   | EXINT13 | 0x0000 | rw | EXINT12 input source configuration<br>These bits are used to select the input source for the EXINT12 external interrupt.<br>0000: GPIOA pin12<br>0001: GPIOB pin12<br>0010: GPIOC pin12<br>0011: GPIOD pin12<br>0100: GPIOE pin12<br>0101: GPIOF pin12<br>0110: GPIOG pin12<br>0111: GPIOH pin12<br>Others: Reserved |

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

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 11 | Reserved | 0x0000 00   | resd | Kept at its default value                                                                                                                                                                                                                                                                                                         |
| Bit 10     | PF15_UH  | 0x0         | rw   | <p>PF15 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PF15 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_OTYPER&amp;GPIOx_HDRV become invalid.</p> |
| Bit 9      | PF14_UH  | 0x0         | rw   | <p>PF14 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PF14 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_OTYPER&amp;GPIOx_HDRV become invalid.</p> |
| Bit 8      | PD15_UH  | 0x0         | rw   | <p>PD15 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PD15 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_OTYPER&amp;GPIOx_HDRV become invalid.</p> |
| Bit 7      | PD14_UH  | 0x0         | rw   | <p>PD14 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PD14 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_OTYPER&amp;GPIOx_HDRV become invalid.</p> |
| Bit 6      | PD13_UH  | 0x0         | rw   | <p>PD13 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PD13 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_OTYPER&amp;GPIOx_HDRV become invalid.</p> |
| Bit 5      | PD12_UH  | 0x0         | rw   | <p>PD12 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PD12 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_OTYPER&amp;GPIOx_HDRV become invalid.</p> |
| Bit 4: 3   | Reserved | 0x0         | rw   | Kept at its default value                                                                                                                                                                                                                                                                                                         |
| Bit 2      | PB10_UH  | 0x0         | rw   | <p>PB10 Ultra high sourcing/sinking strength<br/>This bit is written by software to control the PB10 PAD sourcing/sinking strength.<br/>0: Not active<br/>1: Corresponding GPIO is switched to ultra-high sourcing/sinking strength</p>                                                                                           |

When this bit is set, the control bits of GPIOx\_OTYPER&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 the 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_OTYPER&GPIOx_HDRV become invalid. |
| Bit 0 | PB3_UH | 0x0 | rw | PB3 Ultra high sourcing/sinking strength<br>This bit is written by software to control the 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_OTYPER&GPIOx_HDRV become invalid. |

# 8 External interrupt/Event controller (EXINT)

## 8.1 EXINT introduction

EXINT consists of 23 interrupt lines EXINT\_LINE[22:0], 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 the trigger source in order to generate an interrupt or event.

Figure 8-1 External interrupt/Event controller block diagram



### Main features:

- EXINT 0~15 mapping IO can be configured independently
- Independent trigger selection on each interrupt line
- Independent enable bit on each interrupt
- Independent enable bit on each event
- Up to 23 software trigger that can be generated and cleared independently
- Independent status bit on each interrupt
- Each interrupt can be cleared independently.

## 8.2 Function overview and configuration procedure

With up to 23 interrupt lines EXINT\_LINE[22:0], EXINT can detect not only GPIO external interrupt sources but also seven internal sources such as PVM output, ERTC alarm events and time stamp events, ERTC wakeup events, OTGFS1/OTGFS2 events and Ethernet wakeup events through edge detection mechanism, where, GPIO interrupt sources can be selected with IOMUX\_EXINTCx register. It should be noted that these input sources are mutually exclusive. For example, EXINT\_LINE0 is allowed to select only 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 register. 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 register, 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 IOMUX\_EXINTCx register (This is required if GPIO is used as an interrupt source).
- Select an trigger mode by setting EXINT\_POLCFG1 and EXINT\_POLCFG2 register.

- Enable interrupt or event by setting EXINT\_INTEN and EXINT\_EVTEN register.
- Generate software trigger by setting EXINT\_SWTRG register (This is applied to only software trigger interrupt).

#### Interrupt clear procedure

- Writing “1” to the EXINT\_INTSTS register to clear the interrupts generated, and the corresponding bits in the EXINT\_SWTRG register.

### 8.3 EXINT registers

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

Table 8-1 shows EXINT register map and their reset value.

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.<br>Interrupt enable or disable on line x<br>0: Interrupt request is disabled.       |
| Bit 22: 0  | INTENx   | 0x00000     | rw   | 1: Interrupt request is enabled.<br>Note: Bit 19 is applied to only AT32F434/437A and is reserved otherwise. |

#### 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.<br>Event enable or disable on line x<br>0: Event request is disabled.           |
| Bit 22: 0  | EVTENx   | 0x00000     | rw   | 1: Event request is enabled.<br>Note: Bit 19 is applied to only AT32F437/437a and is reserved otherwise. |

#### 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.<br>Rising polarity configuration bit on line x<br>These bits are used to select a rising edge to trigger an interrupt and event on line x. |
| Bit 22: 0  | RPx      | 0x00000     | rw   | 0: Rising trigger on line x is disabled.<br>1: Rising trigger on line x is enable.<br>Note: Bit 19 is applied to only AT32F437/437A and is reserved otherwise.      |

### 8.3.4 Polarity configuration register 2 (EXINT\_ POLCFG2)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                              |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Forced to be 0 by hardware.<br>Falling polarity configuration bit on line x<br>These bits are used to select a falling edge to trigger an interrupt and event on line x. |
| Bit 22: 0  | FPx      | 0x00000     | rw   | 0: Falling trigger on line x is disabled.<br>1: Falling trigger on line x is enabled.<br>Note: Bit 19 is applied to only AT32F437/437A and is reserved otherwise.        |

### 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.<br>Software trigger on line x<br>If the corresponding bit in EXINT_INTEN register is 1, the software writes to this bit. The hardware sets the corresponding bit in the EXINT_INTSTS automatically to generate an interrupt.                                                                                                                                                            |
| Bit 22: 0  | SWTx     | 0x00000     | rw   | If the corresponding bit in the EXINT_EVTEN register is 1, the software writes to this bit. The hardware generates an event on the corresponding interrupt line automatically.<br>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 applied to only AT32F437/437A and is reserved otherwise. |

### 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.<br>Line x status bit<br>0: No interrupt occurred.                                                           |
| Bit 22: 0  | LINEx    | 0x00000     | Rw1c | 1: Interrupt occurred.<br>Note: This bit is cleared by writing 1. Bit 19 is applied to only AT32F437/437A and is reserved otherwise. |

## 9 DMA controller (DMA)

### 9.1 Introduction

Direct memory access (DMA) controller is designed for 32-bit MCU applications with the aim of enhancing system performance and reducing the generation of interrupts.

There are two DMA controllers in the microcontroller. Each controller contains 7 DMA channels. Each channel manages 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 flexible mapping

Figure 9-1 DMA block diagram



Note: The number of DMA peripherals in Figure 9-1 may decrease depending on different models.

## 9.3 Function overview

### 9.3.1 DMA configuration

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

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

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

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

#### 3. Configure the amount of data to be transferred in the DMA\_CxDTCNT 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\_CxCTRL 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), peripheral-to-memory (P2M)

- **Address incremented mode (PINCM/MINCM)**

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

- **Circular mode (LM)**

In circular mode, the contents in the DMA\_CxDTCNT 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\_CxCTRL 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 MWIDHT bits in the DMA\_CxCTRL register. When PWIDHT is not equal to MWIDHT, it can be aligned according to the settings of PWIDHT/ MWIDHT.

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



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



Figure 9-5 PWIDTH: word, MWIDTH: byte



### 9.3.5 Errors

Table 9-1 DMA error event

| Error event    |                                                          |
|----------------|----------------------------------------------------------|
| 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 interrupt requests

| 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.

EXINT LINE is used as the trigger input for request generators and the synchronized input for requests.

### 9.4.1 DMAMUX functional 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\_MUXGxCTR 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 is used in the DMA\_MUXGxCTRL register 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 is set in the DMA\_MUXCxCTRL register, 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

| DMAMUX request | Source        | DMAMUX request | Source        | DMAMUX request | Source         | DMAMUX request | Source      |
|----------------|---------------|----------------|---------------|----------------|----------------|----------------|-------------|
| 1              | DMA_MUXREQG1  | 33             | UART5_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             | ADC2          | 68             | TMR4_CH2       | 100            | reserved    |
| 5              | ADC1          | 37             | ADC3          | 69             | TMR4_CH3       | 101            | reserved    |
| 6              | DAC1          | 38             | reserved      | 70             | TMR4_CH4       | 102            | reserved    |
| 7              | reserved      | 39             | SDIO1         | 71             | TMR4_OVERFLOW  | 103            | SDIO2       |
| 8              | TMR6_OVERFLOW | 40             | QSPI1         | 72             | TMR5_CH1       | 104            | QSPI2       |
| 9              | TMR7_OVERFLOW | 41             | DAC2          | 73             | TMR5_CH2       | 105            | DVP         |
| 10             | SPI1_RX       | 42             | TMR1_CH1      | 74             | TMR5_CH3       | 106            | SPI4_RX     |
| 11             | SPI1_TX       | 43             | TMR1_CH2      | 75             | TMR5_CH4       | 107            | SPI4_TX     |
| 12             | SPI2_RX       | 44             | TMR1_CH3      | 76             | TMR5_OVERFLOW  | 108            | reserved    |
| 13             | SPI2_TX       | 45             | TMR1_CH4      | 77             | TMR5_TRIG      | 109            | reserved    |
| 14             | SPI3_RX       | 46             | TMR1_OVERFLOW | 78             | reserved       | 110            | I2S2_EXT_RX |
| 15             | SPI3_TX       | 47             | TMR1_TRIG     | 79             | reserved       | 111            | I2S2_EXT_TX |
| 16             | I2C1_RX       | 48             | TMR1_HALL     | 80             | reserved       | 112            | I2S3_EXT_RX |
| 17             | I2C1_TX       | 49             | TMR8_CH1      | 81             | reserved       | 113            | I2S3_EXT_TX |
| 18             | I2C2_RX       | 50             | TMR8_CH2      | 82             | reserved       | 114            | USART6_RX   |
| 19             | I2C2_TX       | 51             | TMR8_CH3      | 83             | reserved       | 115            | USART6_TX   |
| 20             | I2C3_RX       | 52             | TMR8_CH4      | 84             | reserved       | 116            | UART7_RX    |
| 21             | I2C3_TX       | 53             | TMR8_OVERFLOW | 85             | reserved       | 117            | UART7_TX    |
| 22             | reserved      | 54             | TMR8_TRIG     | 86             | TMR20_CH1      | 118            | UART8_RX    |
| 23             | reserved      | 55             | TMR8_HALL     | 87             | TMR20_CH2      | 119            | UART8_TX    |
| 24             | USART1_RX     | 56             | TMR2_CH1      | 88             | TMR20_CH3      | 120            | reserved    |
| 25             | USART1_TX     | 57             | TMR2_CH2      | 89             | TMR20_CH4      | 121            | reserved    |
| 26             | USART2_RX     | 58             | TMR2_CH3      | 90             | TMR20_OVERFLOW | 122            | reserved    |
| 27             | USART2_TX     | 59             | TMR2_CH4      | 91             | reserved       | 123            | reserved    |
| 28             | USART3_RX     | 60             | TMR2_OVERFLOW | 92             | reserved       | 124            | reserved    |
| 29             | USART3_TX     | 61             | TMR3_CH1      | 93             | TMR20_TRIG     | 125            | reserved    |
| 30             | UART4_RX      | 62             | TMR3_CH2      | 94             | TMR20_HALL     | 126            | TMR2_TRIG   |
| 31             | UART4_TX      | 63             | TMR3_CH3      | 95             | reserved       | 127            | TMR4_TRIG   |
| 32             | UART5_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 | 29         | 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 the SYNCOVFCx bit 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

Table 9-5 shows DMA register map and their reset values.

These peripheral registers must 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_MUXSYNCCLR | 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                                                                                                                                                                     |
|--------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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   | Channel7 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   | Channel7 global event flag<br>0: No transfer error, half transfer or transfer complete event occurred.<br>1: Transfer error, half transfer or transfer complete event occurred. |
| 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 event occurred.<br>1: Transfer error, half transfer or transfer complete event |
| 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 event occurred.<br>1: Transfer error, half transfer or transfer complete event |
| 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 event occurred.<br>1: Transfer error, half transfer or transfer complete event |
| 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 event occurred.<br>1: Transfer error, half transfer or transfer complete event |
| 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 event occurred.<br>1: Transfer error, half transfer or transfer complete event |
| 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 event occurred.<br>1: Transfer error, half transfer or transfer complete event |

## 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                                                                                                                      |
|--------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------|
| 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 DTERRF 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 in the 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF7, HDTF7, FDTF7 and GF7 flag 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF6, HDTF6, FDTF6 and GF6 flag 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF5, HDTF5, FDTF5 and GF5 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF4, HDTF4, FDTF4 and GF4 flag 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF3, HDTF3, FDTF3 and GF3 flag 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF2, HDTF2, FDTF2 and GF2 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 interrupt flag clear<br>0: No effect<br>1: Clear the DTERRF1, HDTF1, FDTF1 and GF1 in the DMA_STS 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 | 0x000000    | 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>1: 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.<br>Number of data to transfer                                                                                                                                                                                                                                                                                     |
| Bit 15: 0  | CNT      | 0x0000      | rw   | The number of data to transfer is from 0x0 to 0xFFFF. This register can only be written when the CHEN bit in the corresponding channel is set 0. The value is decremented after each DMA transfer.<br><br>Note: This register holds the number of data to transfer, instead of transfer size. The transfer size is calculated by data width. |

## 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   | Peripheral base address<br>Base address of peripheral data register is the source or destination of data transfer.<br><br>Note: The register can only be written when the CHEN bit in the corresponding channel is set 0. |

## 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   | Memory base address<br>Memory address is the source or destination of data transfer.<br><br>Note: The register can only be written when the CHEN bit in the corresponding channel is set 0. |

## 9.5.7 DMAMUX selection register (DMA\_MUXSEL)

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

| Bit       | Name     | Reset value | Type | Description                                             |
|-----------|----------|-------------|------|---------------------------------------------------------|
| Bit 31: 0 | 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     |

|            |           |      |      |                                                                                                                                                                                                                                                  |
|------------|-----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |           |      |      | DMA request count                                                                                                                                                                                                                                |
| Bit 23: 19 | REQCNT    | 0x00 | rw   | 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 only when both SYNCEN and EVTGEN bits are low. |
|            |           |      |      | Synchronization polarity<br>This field defines the polarity of the selected synchronization input.<br>0x0: No events<br>0x1: Rising edge<br>0x2: Falling edge<br>0x3: Rising edge and falling edge                                               |
| Bit 18: 17 | SYNCPOL   | 0x0  | rw   |                                                                                                                                                                                                                                                  |
| Bit 16     | SYNCEN    | 0x0  | rw   | Synchronization enable<br>0: Synchronization disabled<br>1: Synchronization enabled                                                                                                                                                              |
| Bit 15: 10 | Reserved  | 0x00 | resd | Kept at its default value.                                                                                                                                                                                                                       |
| Bit 9      | EVTGEN    | 0x0  |      | Event generation enable<br>0: Event generation is disabled<br>1: Event generation is 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>Select DMA request. Refer to DMAMUX table for more information.                                                                                                                                                            |

### 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>These bits define the number of DMA requests (GNBREQ + 1) to be generated when a trigger event occurs.<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 events<br>0x1: Rising edge<br>0x2: Falling edge<br>0x3: Rising and falling edges       |
| Bit 16     | GEN      | 0x0         | rw   | DMA request generation enable<br>0: DMA request generation is disabled<br>1: DMA request generation is 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>This field is used to select the DMA trigger input for DMA request generation. |

### 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: 8 | Reserved | 0x0000 00   | resd | Kept at its default value.                                                                                                                          |
| Bit 7: 0  | SYNCOVF  | 0x00        | ro   | Synchronization overrun interrupt flag<br>When the DMA request count is less than REQCNT, this bit is set while a new synchronization event occurs. |

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

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

| Bit       | Name     | Reset value | Type | Description                                                                                                                               |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x0000 00   | resd | Kept at its default value.                                                                                                                |
| Bit 7: 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      | Register | 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 CRC32/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.

Figure 10-1 CRC calculation unit block diagram



### Main features

- Use CRC-32 code
- Support the generation of polynomial
- 4 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 with CRC\_DT register after each CRC reset.

## 10.2 CRC function description

According to CRC calculation principle, the input data is taken as dividend, and the generator polynomial as a division. Using mod 2 division logic, the input data divided by the generator polynomial gets a remainder, that is, the CRC value.

### CRC calculation procedure

- Input data reverse. After data input, reverse input data depending on the REVID value in the CRC\_CTRL register.

- Initialization. The first data input needs to be XOR-ed with the initial value defined in the CRC\_IDT register. If it is not the first data input, the initial value is the previously calculated result.
- CRC calculation. Dividing the input data by the generator polynomial (0x4C11DB7) using mod 2 division method produces a remainder, that is, CRC value.
- Output data toggle. Select whether to perform word toggle before output CRC value through the REVOD bit in the CRC\_CTRL register.
- XOR calculation. The XOR-ed result is fixed at 0x0000 0000

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

- 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$
- Initial value: 0xFFFF FFFF, in order to avoid that 1-byte 0x00 data to be calculated has the same result as that of multi-byte 0x00.
- XOR-ed value: 0x0000 0000, indicating that the CRC result will not be XOR-ed.

#### Toggle function

- Byte reverse, 8 bits in a group, and sequence is reversed within the group. As shown in the figure below, if the original data is 0x12345678, it is reversed as 0x482C6A1E.
- Half-word reverse, 16 bits in a group, and sequence is reversed within the group.
- Word reverse, 32 bits in a group, and sequence is reversed within the group.

Figure 10-2 Diagram of byte reverse



## 10.3CRC registers

CRC\_DT register can be accessed by bytes (8 bits), half-words (16 bits) or words (32 bits). Other registers have to be accessed by words (32 bits).

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>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>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>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 field is used to set the size of polynomial. It is used in conjunction with the CRC_POLY register.<br>00: 32 bits<br>01: 16 bits<br>10: 8 bits<br>11: 7 bits        |
| Bit 2: 1  | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                  |
| Bit 0     | RST       | 0x0         | wo   | Reset CRC calculation unit<br>Set by software. 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 register<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 generated polynomial is a divisor in CRC calculation. Using CRC32 mode, this polynomial coefficient is 0x4C11DB7. Users can also set the polynomial coefficient according to their needs. |

# 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
  - Stand mode (100 kHz), fast mode(400 kHz) and fast mode plus (1 MHz)
  - 7-bit and 10-bit address modes
  - Two 7-bit slave addresses (two 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 SMBus2.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, whereas up to 400kHz in fast 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

Figure 11-2 shows the block diagram of I<sup>2</sup>C function.

Figure 11-2 I<sup>2</sup>C function 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 GENSTART=1 is set (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 in the I2C\_CTRL1 register to reduce noise on bus on a large scale. The filter time is DLFT x t<sub>I2C\_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.
- ADDR7F is set, with SIDR indicating the transmission direction
  - When SIDR =0, slave enters receiver mode, starting receiving data.
  - When SIDR =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 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 ADDR 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 I2C will hold the SCL bus low to wait for the software to read I2C\_RXDT register.
- Data transmission: If no data is written when the ADDR is cleared, TDBE= 1 in the I2C\_STS, then the SCL line will be pulled down until the 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 down until data is written to the I2C\_TXDT.
- When slave data control mode is selected (SCTRL=1 in the I2C\_CTRL1) and RLDE=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 before a non-zero value is written to the CNT bit in the 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 our 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 there is data to be read in the I2C\_RXDT register before the next ACK signal, an overflow will occur, and the OUF bit will also be set in the I2C\_STS register.
- 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 will also be set in the I2C\_STS register.

### 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] 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} = (DLFT + 3) \times t_{I2C\_CLK} - t_f$$

$t_{SYNC}$  consists of three parts:

  - SCL falling edge time  $t_f$
  - Digital filter input latency ( $DLFT \times t_{I2C\_CLK}$ )
  - 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_r$$

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] 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} = (SCLH + 1) \times (DIV + 1) \times t_{I2C\_CLK}$$

- SCL low signal width

$$T_{Low} = (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.9       | 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] in the I2C\_CTRL2 ) is applicable to master mode. 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\_CTRL2 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 has to be set in the I2C\_CTRL2 register 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, the remaining bytes are 600-255=345 bytes
  - Step 3: After the completion of 255-byte data transfer, the TCRLD is set in the I2C\_STS register,

and then configure CNT[7:0]=255 for continuous transfer, the remaining bytes are 345-255=90

- Step 4: After the completion of the second 255-byte data transfer, the TCRLD is set 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 is disabled)

- Stop data transfer automatically (ASTOPEN=1 in the I2C\_CTRL2)
  - 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)
  - When the number of data programmed in the CNT[7:0] has been fully transferred, the TDC will be set in the I2C\_STS register, and the SCL, at this point, will be pulled low, an interrupt generated if TDClEN is enabled. 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\_CTRL2 register so that the slave is able to control ACK/NACK signals 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 is set in the I2C\_STS register, and the slave will pull the SCL bus low between the 8<sup>th</sup> and 9<sup>th</sup> 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 8<sup>th</sup> data. Proceed as below: set CNT[7:0]=8, the slave will receive 7 consecutive data, with ACK signals sent. Once the 8<sup>th</sup> 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 table

| Description                                        | RLDEN | ASTOPEN | SCTRL |
|----------------------------------------------------|-------|---------|-------|
| Master transmit/receive RESTART                    | 0     | 0       | x     |
| Master transmit/receive STOP                       | 0     | 1       | x     |
| Slave receive (control ACK/NACK of each byte)      | 1     | x       | 1     |
| Slave transmit/receive (ACK response to all bytes) | x     | 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]

Artery\_I2C\_Timing\_Configuration can be used to configure this register.

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

- ≤255 bytes  
Disable reload mode by setting RLDEN=0 in the I2C\_CTRL2 register  
Set CNT[7:0]=N in the I2C\_CTRL2 register
- >255 bytes  
Enable reload mode by setting RLDEN=1 in the I2C\_CTRL register  
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, ADDRF=1 is asserted in the I2C\_STS register. The ADDRF 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, TDIS=1 in the I2C\_STS register;
2. Writing 1 to the TXDT register, and data is immediately moved to the shift register;
3. TXDT register becomes empty, TDIS=1 again;
4. Writing 2 to the TXDT register, 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: write 255 to the CNT bit, N=N-255, TCRLD is cleared, and data transfer continues.

Remaining bytes N≤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, ADDRF=1 in the I2C\_STS register, clear ADDRF 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] bit;
4. If TCRLD=1 (reload mode) in the I2C\_STS, the following two circumstances should be noted:  
Remaining bytes N>255: write 255 to the CNT bit, N=N-255, TCRLD is cleared, and data transfer continues.  
Remaining bytes N≤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, 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.

When the host 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 of 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 (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]

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

### 2. Set local address 1

- Set address mode:
  - 7-bit address: by setting ADDR1MODE = 0 in the I2C\_OADDR register
  - 10-bit address: by setting ADDR1MODE = 1 in the I2C\_OADDR 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 of 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 is cleared by setting ADDRC=1 of the I2C\_CLR register.

### 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. Data is then transferred to the shift register after writing 1 to the TXDT register;
3. The TXDT register then becomes empty, and the TDIS is set again;
4. TDIS is cleared by writing 2 to the TXDT register;
5. Repeat steps 3 and 4 until the completion 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 writing 1 to the ACKFAILC.
7. Wait for the generation of a STOP condition. Once received, the STOPF is set in the I2C\_STS register. At the end of data transfer, the STOPF is cleared by writing 1 to the STOPC, transmission ends.

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 the TDBE bit through

software, and then write the first data to the TXDT register, the TDBE is cleared.

- Write operation through interrupts or DMA: Clear the TXDT register by setting the TDBE bit through software, then set the TDIS bit 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\_RXDT register becomes empty, the shift register becomes empty, and RDBF=0 in the I2C\_STS register;
2. Upon the receipt of data, RDBF=1; The RDBF is cleared by read operation to the RXDT register;
3. Repeat step 2 until the completion of all data transfer;
4. 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, transfer ends.

In slave receive mode, the slave byte control mode 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 Section 114.2 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 transmission

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



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



**Slave receive**Figure 11-12 I<sup>2</sup>C slave receive flowFigure 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.

### Differences 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 I2C\_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 is enabled to recognize the 0b0001000x (default host address)

### 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 responses to ARA (Alert Response Address) 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 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. The 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 configurations | Enable bit | Timeout calculation                         |
|-----------------|----------------------|------------|---------------------------------------------|
| $t_{TIMEOUT}$   | TOMODE=0             | TOEN=1     | (TOTIME + 1) x 2048 x T <sub>I2C_CLK</sub>  |
| $t_{LOW:SEXT}$  | -                    | EXTEN=1    | (EXTTIME + 1) x 2048 x T <sub>I2C_CLK</sub> |
| $t_{LOW:MEXT}$  | -                    | EXTEN=1    | (EXTTIME + 1) x 2048 x T <sub>I2C_CLK</sub> |

### 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 Section 11.4.2 for more information.

Table 11-5 SMBus mode configuration

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

### How to use the interface in SMBus mode

1. Set SMBus default address acknowledgement:  
HADDREN=1: Master default address acknowledged (0b0001000x)  
DEVADDREN=1: Device default address acknowledged (0b1100001x)
2. Configure PEC.
3. Slave receive byte control mode can be enabled (with SCTRL bit in the I2C\_CTRL1) in slave mode, if necessary.
4. 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.

### 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. 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

### 3. 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.

### 4. 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.

### 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 the 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, ADDRF=1 is asserted in the I2C\_STS register. The ADDRF 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, TDIS=1 in the I2C\_STS register;
  2. Writing 1 to the TXDT register, and data is immediately moved to the shift register;
  3. TXDT register becomes empty, TDIS=1 again;
  4. Writing 2 to the TXDT register, TDIS is cleared;
  5. Repeat step 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 receipt 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.

**SMBus master transmission flow**

Figure 11-14 SMBus master transmission flow



Figure 11-15 SMBus master transmission timing

**SMBus master receive flow**

Figure 11-16 SMBus master receive flow



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. I<sup>2</sup>C clock initialization (by setting the I<sup>2</sup>C\_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]

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

### 2. Set local address

- Set 7-bit address mode: by setting ADDR1MODE = 0 in the I2C\_OADDR 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 host: device default address acknowledged (0b1100001x) by setting DEVADDREN=1;
- Enable PEC calculation: Set 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 of 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.

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. Data is then transferred to the shift register after writing 1 to the TXDT register;
3. The TXDT register then becomes empty, and the TDIS is set again;
4. TDIS is cleared by writing 2 to the TXDT register;
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 an NACK signal. Once received, the ACKFAILF is set in the I2C\_STS register. The ACKFAILF flag is cleared by writing 1 to the ACKFAILC.
8. Wait for the generation of a STOP condition. Once received, the STOPF is set in the I2C\_STS register. At the end of data transfer, the STOPF is cleared by writing 1 to the STOPC, 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. The RDBF is cleared by read operation to the RXDT register;
4. NACKEN bit of the I2C\_CTRL 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 step 2/3/4 until the completion of data reception (N-1).
6. Set RLDEN=0 of the I2C\_CTRL2 register to disable reload mode. Set CNT=1 to repeat step 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, transfer ends.

**SMBus slave transmission**

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 DMAEN=1 in the I2C\_CTRL2 register. Once the TDBE bit in the I2C\_STS1 register is set, the data is loaded from the programmed memory to the I2C\_DT register through DMA.
8. When the number of data transfers, programmed in the DMA controller, is reached (DMA\_CxDTCNT=0), the data transfer is complete (An interrupt is generated if enabled).
9. Master transmitter: Refer to I<sup>2</sup>C master communication flow for the generation of STOP condition.

Slave transmitter: Refer to I<sup>2</sup>C slave communication flow for the generation of STOP condition.

### Reception using DMA (DMAREN=1)

1. Set the peripheral address (DMA\_CxPADDR = I2C\_RXDT address)
2. Set the memory address (DMA\_CxMADDR = memory address)
3. The transmission directions 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 DMAEN=1 in the I2C\_CTRL2 register. Once the RDBE bit in the I2C\_STS1 register is set, 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\_CxDTCNT=0), the data transfer is complete (An interrupt is generated if enabled).
9. Master receiver: Refer to I<sup>2</sup>C master communication flow for the generation of STOP condition.

Slave receiver: Refer to I<sup>2</sup>C slave communication flow for the generation of 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. [Table 11-6](#) presents the manageable error events:

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 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|---------|
| <b>Overrun/Underrun (OUF)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |        |         |
| In slave mode, an underrun/overrun may appear if the clock stretching feature is disabled (STRETCH=1 in the I2C_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 I2C_STS register, sending 0xFF to the bus.                                                                                                                                                                                       |        |        |         |
| In slave receive mode: 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.                                                                                                                                                                    |        |        |         |
| <b>Arbitration lost (ARLOST)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |        |         |
| An arbitration lost may occur when the device controls the SDA line to output high level but the actual bus output is low.                                                                                                                                                                                                                                                                                                                                                                     |        |        |         |
| <ul style="list-style-type: none"> <li>— Master transmit: An arbitration may occur during an address transfer and a data transfer</li> <li>— Master receive: An arbitration may occur during an address transfer and an ACK response</li> <li>— Slave transmit: An arbitration may occur during a data transfer</li> <li>— Slave receive: An arbitration may occur during an ACK response</li> </ul>                                                                                           |        |        |         |
| Once an arbitration lost is detected, the ARLOST is set by hardware in the I2C_STS register. The SCL and SDA buses will be released and go automatically back to slave mode.                                                                                                                                                                                                                                                                                                                   |        |        |         |
| <b>Bus error (BUSERR)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |        |         |
| 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. When the SCL is high:                                                                                                                                                                                                                                                                      |        |        |         |
| <ul style="list-style-type: none"> <li>— SDA changes from 1 to 0: a misplaced START condition</li> <li>— SDA changes from 0 to 1: a misplaced STOP condition</li> </ul>                                                                                                                                                                                                                                                                                                                        |        |        |         |
| Both of these conditions above may trigger a bus error. Once it occurs, the BUSERR is set by hardware in the I2C_STS register.                                                                                                                                                                                                                                                                                                                                                                 |        |        |         |
| <b>Packet error checking (PECERR)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |        |         |
| 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 I2C_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.                                                                                                                                                                                                                                                                                                                                                                                                                 |        |        |         |
| <b>SMBus alert (ALERTF)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |        |         |
| 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 I2C_STS register.                                                                                                                                                                                                                                     |        |        |         |
| <b>Timeout error (TMOUT)</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |        |         |
| 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     | ERRIEN             |
| Timeout error                            | TMOUT      |                    |
| PEC error                                | PECERR     |                    |
| 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®-M4 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 values

| 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.                                                                                                    |
|            |           |             |      | PEC calculation enable                                                                                                        |
| Bit 23     | PECEN     | 0x0         | rw   | 0: PEC calculation disabled<br>1: PEC calculation enabled                                                                     |
|            |           |             |      | SMBus alert enable / pin set                                                                                                  |
|            |           |             |      | To enable SMBus master alert feature:                                                                                         |
|            |           |             |      | 0: SMBus alert disabled                                                                                                       |
| Bit 22     | SMBALERT  | 0x0         | rw   | 1: SMBus alert enabled                                                                                                        |
|            |           |             |      | To enable SMBus slave alert address:                                                                                          |
|            |           |             |      | 0: Pin high                                                                                                                   |
|            |           |             |      | 1: Pin low, response address 0001100x                                                                                         |
|            |           |             |      | SMBus device default address enable                                                                                           |
| Bit 21     | DEVADDREN | 0x0         | rw   | 0: SMBus device default address disabled<br>1: SMBus device default address enabled, response device default address 1100001x |
|            |           |             |      | SMBus host address enable                                                                                                     |
| Bit 20     | HADDREN   | 0x0         | rw   | 0: SMBus host address disabled<br>1: SMBus host address enabled, response host address 0001000x                               |
|            |           |             |      | General call address enable                                                                                                   |
| Bit 19     | GCAEN     | 0x0         | rw   | 0: General call address disabled<br>1: General call address enabled, response 0000000x                                        |
| Bit 18     | Reserved  | 0x0         | res  | Kept at its default value.                                                                                                    |
|            |           |             |      | Clock stretching mode                                                                                                         |
| Bit 17     | STRETCH   | 0x0         | rw   | 0: Clock stretching mode enabled<br>1: Clock stretching mode disabled                                                         |
|            |           |             |      | Note: This feature is valid in slave mode only.                                                                               |
|            |           |             |      | Slave receive data control                                                                                                    |
| Bit 16     | SCTRL     | 0x0         | rw   | 0: Slave receive data disabled<br>1: Slave receive data enabled                                                               |
|            |           |             |      | DMA receive data request enable                                                                                               |
| Bit 15     | DMAREN    | 0x0         | rw   | 0: DMA receive data request disabled<br>1: DMA receive data request enabled                                                   |
|            |           |             |      | DMA Transmit data request enable                                                                                              |
| Bit 14     | DMATEN    | 0x0         | rw   | 0: DMA Transmit data request disabled<br>1: DMA Transmit data request enabled                                                 |
| Bit 13: 12 | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                    |
|            |           |             |      | Digital filter value                                                                                                          |
| Bit 11: 8  | DELT      | 0x0         | rw   | Filter time = DFLT x T <sub>I2C_CLK</sub><br>The glitches less than the filter time on the SCL bus will be filtered.          |
|            |           |             |      | Error interrupt enable                                                                                                        |
| Bit 7      | ERRIEN    | 0x0         | rw   | 0: Error interrupt disabled<br>1: Error interrupt enabled                                                                     |
|            |           |             |      | Data transfer complete interrupt enable                                                                                       |
| Bit 6      | TDCIEN    | 0x0         | rw   | 0: Data transfer complete interrupt disabled<br>1: Data transfer complete interrupt enabled                                   |
|            |           |             |      | Stop generation complete interrupt enable                                                                                     |
| Bit 5      | STOPIEN   | 0x0         | rw   | 0: Stop generation complete interrupt disabled<br>1: Stop generation complete interrupt enabled                               |

|       |           |     |      |                                                                                                                      |
|-------|-----------|-----|------|----------------------------------------------------------------------------------------------------------------------|
| Bit 4 | ACKFAILEN | 0x0 | rw   | Acknowledge fail interrupt enable<br>0: Acknowledge fail interrupt disabled<br>1: Acknowledge fail interrupt enabled |
| Bit 3 | ADDRIEN   | 0x0 | rw   | Address match interrupt enable<br>0: Address match interrupt disabled<br>1: Address match interrupt enabled          |
| Bit 2 | RDIEN     | 0x0 | resd | Data receive interrupt enable<br>0: Data receive interrupt disabled<br>1: Data receive interrupt enabled             |
| Bit 1 | TDIEN     | 0x0 | rw   | Data transmit interrupt enable<br>0: Data transmit interrupt disabled<br>1: Data transmit interrupt enabled          |
| Bit 0 | I2CEN     | 0x0 | rw   | I <sup>2</sup> C peripheral enable<br>0: Disabled<br>1: Enabled                                                      |

### 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                                                    |
| 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: Send data reload mode disable<br>1: Send data reload mode enabled                                      |
| Bit 23: 16 | CNT[7: 0]   | 0x00        | rw   | Transmit data counter                                                                                                                     |
| Bit 15     | NACKEN      | 0x0         | rw   | Not acknowledge enable<br>0: Acknowledge enabled<br>1: Acknowledge disabled                                                               |
| Bit 14     | GENSTOP     | 0x0         | rw   | Generate stop condition<br>0: No stop generation<br>1: stop generation                                                                    |
| Bit 13     | GENSTART    | 0x0         | rw   | Generate start condition<br>0: No start generation<br>1: Start generation                                                                 |
| 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 transfer direction<br>0: Receive<br>1: Transmit                                                                               |
| 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      | rw   | 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 mode<br>0: 7-bit address mode<br>1: 10-bit address mode           |
| Bit 9: 0   | ADDR1[9: 0] | 0x000       | rw   | Own address1<br>In 7-bit address mode, bit 0 and bit [9: 8] don't care.       |

### 11.7.4 Own address register 2 (I2C\_OADDR2)

| Bit        | Name            | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                 |
|------------|-----------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved        | 0x000       | 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 |
| Bit 7: 1   | ADDR2[7: 1]     | 0x00        | rw   | Own address 2<br>7-bit address mode                                                                                                                                                                                                                                                                                         |
| 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>$\text{DIV} = (\text{DIVH} \ll 4) + \text{DIVL}$  |
| Bit 23: 20 | SCLD[3: 0] | 0x0         | rw   | SCL output delay<br>$T_{SCLD} = (SCLD + 1) \times (\text{DIV} + 1) \times T_{I2C\_CLK}$ |
| Bit 19: 16 | SDAD[3: 0] | 0x0         | rw   | SDA output delay<br>$T_{SDAD} = (SDAD + 1) \times (\text{DIV} + 1) \times T_{I2C\_CLK}$ |
| Bit 15: 8  | SCLH[7: 0] | 0x00        | rw   | SCL high level<br>$T_{SCLH} = (SCLH + 1) \times (\text{DIV} + 1) \times T_{I2C\_CLK}$   |
| Bit 7: 0   | SCLL[7: 0] | 0x00        | rw   | SCL low level<br>$T_{SCLL} = (SCLL + 1) \times (\text{DIV} + 1) \times T_{I2C\_CLK}$    |

### 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: Cumulative clock low extend timeout disabled<br>1: Cumulative clock low extend timeout 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}$ .                                                                                        |
| Bit 15     | TOEN          | 0x0         | rw   | Detect clock low/high timeout enable<br>0: Clock low/high timeout detection disabled<br>1: clock low/high timeout detection enabled                                                                      |

|            |              |       |     |                                                                                                                                                                                                                                                |
|------------|--------------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |              |       |     | 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                                                                                                                                                  |
| 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) x 2048 x $T_{I2C\_CLK}$<br>For clock high level detection (TOMODE = 1):<br>Timeout duration = (TOTIME + 1) x 4 x $T_{I2C\_CLK}$ |

## 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 transfer 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;<br>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    | Overrun or underrun flag<br>In transmission mode:<br>0: No overrun or underrun<br>1: Underrun<br>In reception mode:<br>0: No overrun or underrun<br>1: Overrun                                                                                                                                                                                      |
| Bit 9      | ARLOST     | 0x0         | r    | Arbitration lost flag<br>0: No arbitration lost detected.<br>1: Arbitration lost detected.                                                                                                                                                                                                                                                          |
| Bit 8      | BUSERR     | 0x0         | rw0c | Bus error flag<br>0: No Bus error occurred<br>1: Bus error occurred                                                                                                                                                                                                                                                                                 |
| Bit 7      | TCRLD      | 0x0         | r    | Data transfer complete, waiting for data load<br>0: Data transfer is not complete yet<br>1: Data transfer is complete<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)                                                                                                                                                                                                                                          |

|       |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 1: Data transfer is completed (shift register become empty and all data has been sent to the bus)<br>This bit is set when ASTOPEN = 0, RLDEN = 0, CNT = 0. 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 | ADDRHF   | 0x0 | r    | 0~7 bit address head match flag<br>0: 0~7 bit address head mismatch<br>1: 0~7 bit address head 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 not empty<br>1: I2C_TXDT empty<br>This bit is only used to indicate the current status of the I2C_TXDT register. The I2C_TXDT register can be cleared by writing 1 through software.                                                                                                                                                         |

### 11.7.8 Status clear register (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>Overload / underload flag is cleared by writing 1.                             |
| Bit 9      | ARLOSTC  | 0x0         | w    | Clear arbitration lost flag<br>Arbitration lost flag is cleared by writing 1.                                     |
| Bit 8      | BUSERRC  | 0x0         | w    | Clear bus error flag<br>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>Stop condition generation complete flag is cleared by writing 1. |
| Bit 4      | ACKFAILC | 0x0         | w    | Clear acknowledge failure flag<br>Acknowledge failure flag is cleared by writing 1.                               |
| Bit 3      | ADDRC    | 0x0         | w    | Clear 0~7 bit address match flag<br>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     | 0x000000    | res  | Kept at its default value. |
| Bit 7: 0  | PECVAL[7: 0] | 0x00        | r    | PEC value                  |

### 11.7.10 Receive data register (I2C\_RXDT)

| Bit       | Name     | Reset value | Type | Description                |
|-----------|----------|-------------|------|----------------------------|
| Bit 31: 8 | Reserved | 0x000000    | res  | Kept at its default value. |
| Bit 7: 0  | DT[7: 0] | 0x00        | r    | Receive data register      |

### 11.7.11 Transmit data register (I2C\_TXDT)

| Bit       | Name     | Reset value | Type | Description                |
|-----------|----------|-------------|------|----------------------------|
| Bit 31: 8 | Reserved | 0x000000    | 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, and CTS/RTS (Clear To Send/Request To Send) hardware flow operation.

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 communication
- Programmable communication modes
  - NRZ standard format (Mark/Space)
  - LIN (Local Interconnection Network)
  - IrDA SIR
  - 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
  - RS-485
  - 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 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 10 interrupt sources with flags
  - CTSF changes
  - LIN break detection
  - Transmit data register empty
  - Transmission complete
  - Receive data register full
  - Idle bus detected
  - Overrun error
  - Framing error
  - Noise error
  - Parity error

## 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 HALFSEL is set 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 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:

Parameters configuration: LINEN=1, CLKEN=0, STOPBN[1:0]=0, SCMEN=0, SLBEN=0, IRDAEN=0 and DBN[1: 0]=0.

LIN master has break frame transmission capability, and thus it is able to send 13-bit low-level LIN synchronous break frame by setting SBF=1.

Similarly, LIN slave has break frame detection capability, and thus it is able to detect 11-bit or 12-bit break frame, depending on whether BFBN=1 or BFBN=0.

Figure 12-2 BFF and FERR detection in LIN mode



## 2. Smartcard mode:

Parameters configuration: SCLEN=1, LINEN=0, SLBEN=0, IRDAEN=0, CLKEN=1, DBN[1: 0]=1, PEN=1, and STOPBN[1: 0]=11.

The polarity, phase and pulse number of the clock can be configured by setting the CLKPOL, CLKPH 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 Smarcard 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:

Parameters configuration: IRDAEN=1, CLKEN=0, STOPBN[1: 0]=0, 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 bit. In infrared low-power mode, the pulse width can be 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. Hardware flow control mode:

RTS and CTS flow control can be enabled by setting RTSEN=1 and CTSEN=1, respectively.

RTS: the RTS becomes active (pull-down means low) as soon as the USART receiver is ready to receive a data. When the data has arrived (starts at each STOP bit) in the receive register, the RTS bit is set, indicating request to stop data transfer at the end of current frame.

CTS: the USART transmitter checks the CTS input before sending next frame. The next data is sent if CTS is active (when low); if CTS becomes inactive (when high) during transmission, it stops sending at the end of current transfer.

Figure 12-5 Hardware flow control



#### 5. 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 the polarity of the DE signal. The TSDT[4: 0] bit is used to define the latency before the transmission of the start bit on the transmitter side, while the TCDT[4: 0] is used to define the latency before the TC flag is set following the stop bit at the end of the last data.

#### 6. Silent mode:

Silent mode can be entered by setting RM=1. It is possible to wake up from silent mode by setting WUM=1 (ID match) and WUM=0 (idle bus), respectively. The ID[7: 0] is configurable. Select ID[7: 0] or ID[3: 0] 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 parity check is disabled, if DBN[1:0]=10, the MSB refers to the USART\_DT[6]; if DBN[1:0]=00, the MSB refers to the USART\_DT[7]; if DBN[1:0]=01, the MSB stands for USART\_DT[8].

When parity check is enabled, if DBN[1:0]=10, the MSB stands for USART\_DT[5]; if DBN[1:0]=00, the MSB stands for USART\_DT[6]; if DBN[1:0]=01, the MSB stands for USART\_DT[7].

When the ID[3: 0] bit is selected, the four LSB bits indicate the ID value; When the ID[7:0] bit is selected, all of the LSB bits indicates the ID value, except for the above parity check bits and MSB bits.

Figure 12-6 Mute mode using Idle line or Address mark detection



#### 7. Synchronous mode:

By setting the CLKEN bit to 1, synchronous mode and clock pin output are enabled. Select CK pin high or low in idle state by setting the CLKPOL bit (1 or 0). Whether to sample data on the second or first edge of the clock depends on 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] 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



The STOPBN bit is used to program one bit (STOPBN=00), 0.5-bit (STOPBN=01), two-bit (STOPBN=10) and 1.5-bit (STOPBN=11) stop bits.

Set the PEN=1 will enable parity control. PSEL=1 indicates Odd parity, while PSEL=0 for Even parity. Once the parity control 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



## 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 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  $\times$  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 equal to or greater than 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 (i.e. PCLK1/PCLK2)

*Note:*

1. Write access to the USART\_BAUDR register before UEN. The baud rate register value 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 fPCLK=36MHz |       |         | fPCLK=72MHz                                          |        |         |                                                   |        |  |
|------------------|-------|---------|------------------------------------------------------|--------|---------|---------------------------------------------------|--------|--|
| N<br>o.          | Kbps  | Actual  | Value<br>programmed<br>in<br>the<br>baud<br>register | Error% | Actual  | Value<br>programmed<br>in the<br>baud<br>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                                                   | NA     | 4500    | 16                                                | 0%     |  |

Taking a baud rate of 115.2Kbps as an example, if fPCLK=36MHz, the value in the baud register should be set to 312(0x38). Based on formula, the calculated baud rate (actual) is  $36000000 / 312 = 115384 = 115.384$ Kbps.

The % error between the desired and actual value is calculated based on the formula: (Calculated actual result-Desired)/desired baud rate\*100%, that is,  $(115.384 - 115.2) / 115.2 * 100\% = 0.15\%$ .

## 12.7 Transmitter

### 12.7.1 Transmitter 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 the 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 the UEN bit.
2. Full-duplex/half-duplex configuration: Refer to [12.2 Full-duplex/half-duplex selector](#).
3. Mode configuration: Refer to [12.3 Mode selector](#).
4. Frame format configuration: Refer to [12.4 USART frame format and configuration](#).
5. Interrupt configuration: Refer to [12.10 Interrupt requests](#).
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 [12.6 Baud rate generation](#).
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 step in non-DMA mode.
10. After the last data expected to be transferred is written, wait until the TDC is set, indicating the end of transfer. The USART cannot be disabled before the flag is set, or 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 TDC/TDBE behavior when transmitting



*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 Receiver 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: UEN bit is set.
2. Full-duplex/half-duplex configuration: Refer to [12.2 Full-duplex/half-duplex selector](#).
3. Mode configuration: Refer to [12.3 Mode selector](#).
4. Frame format configuration: Refer to [12.4 USART frame format and configuration](#).
5. Interrupt configuration: Refer to [12.10 Interrupt requests](#).
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 [12.6 Baud rate generation](#).
8. Receiver enable: REN bit is set.

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 is set.
- The error flag is set when a framing error, noise error or overrun error is detected during reception.
- In DMA mode, the RDNE 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:

- It is handled as a data frame, and the IDLEF bit is set. An interrupt is generated if 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.

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 is set or both ERRIEN and DMAREN are set.
- The ROERR bit is cleared by reading the USART\_STS register and then USART\_DT register in order.

*Note: If ROERR 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. Table 12-2 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              | 1        | Invalid            |
| Any value             | 111/110/101/011        | 1        | 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 7<sup>th</sup>, 8<sup>th</sup> and 9<sup>th</sup> bits, with its oversampling techniques, to distinguish valid data input from noise based on different sampling values, and recover data as well as set 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 bit 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

| <b>DBN[1:0]</b> | <b>DIV[3:0] = 0</b> | <b>DIV[3:0] != 0</b> |
|-----------------|---------------------|----------------------|
| 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 read access to USART\_STS register followed by the USART\_DT read operation.

Figure 12-11 Data sampling for noise detection



## 12.9 Tx/Rx swap

When the TRPSWAP bit (USART\_CTRL2[15]) is set, Tx/Rx pin can be swapped. Two common scenes are listed below:

- If the Tx/Rx were reversed while the user attempts to connect the device externally to a RS-232 chip, they can be swapped through the TRPSWAP bit, without the need of hardware intervention.
- If the user only connected 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 SWAP (USART\_CTRL2[15]) can be modified only when the USART is disabled (UEN=0).

## 12.10 Interrupt requests

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. Table 12-4 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 request

| Interrupt event                              | Event flag            | Enable bit            |
|----------------------------------------------|-----------------------|-----------------------|
| Transmit data register empty                 | TDBE                  | TDBEIEN               |
| CTS flag                                     | CTSCF                 | CTSCFIEN              |
| Transmit data complete                       | TDC                   | TDCIEN                |
| Receive data buffer full                     | RDBF                  | RDBFIEN               |
| Receiver overflow error                      | ROERR                 |                       |
| Idle flag                                    | IDLEF                 | IDLEIEN               |
| Parity error                                 | PERR                  | PERRIEN               |
| Break frame flag                             | BFF                   | BFIEN                 |
| Noise error, overflow error or framing error | NERR or ROERR or FERR | ERRIEN <sup>(1)</sup> |

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 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 can be 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

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

Table 12-6 USART register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| USART_STS   | 0x00   | 0x0000 00C0 |
| USART_DT    | 0x04   | 0x0000 0000 |
| USART_BAUDR | 0x08   | 0x0000 0000 |
| USART_CTRL1 | 0x0C   | 0x0000 0000 |
| USART_CTRL2 | 0x10   | 0x0000 0000 |
| USART_CTRL3 | 0x14   | 0x0000 0000 |
| USART_GTP   | 0x18   | 0x0000 0000 |

### 12.12.1 Status register (USART\_STS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x0000000   | resd | Forced 0 by hardware.                                                                                                                                                                                                                                                                                    |
| 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: Break frame is not detected.<br>1: 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 USART_DT register write operation.<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 USART_STS register followed by a USART_DT write operation; 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 USART_DT register; Option 2: write "0" to this bit)<br>0: Data is not received.<br>1: Data is received.                |
| Bit 4      | IDLEF    | 0x0         | ro   | Idle flag<br>This bit is set by hardware when an idle line is detected. It is cleared by software. (Read USART_DT register followed by a USART_DT read operation)<br>0: No idle line is detected.<br>1: Idle line is detected.                                                                           |
| Bit 3      | ROERR    | 0x0         | ro   | Receiver overflow error<br>This bit is set by hardware when the data is received while the RDNE is still set. It is cleared by software. (Read USART_STS register followed by a USART_DT read operation)<br>0: No overflow error                                                                         |

|       |      |     |    |                                                                                                                                                                                                                                                                                 |
|-------|------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |    | 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.                                                                                                                            |
| Bit 2 | NERR | 0x0 | ro | Noise error<br>This bit is set by hardware when noise is detect on a received frame. It is cleared by software. (Read USART_STS register followed by a USART_DT read operation)<br>0: No noise is detected.<br>1: Noise is detected.                                            |
| Bit 1 | FERR | 0x0 | ro | Framing error<br>This bit is set by hardware when a stop bit error (low), excessive noise or break frame is detected. It is cleared by software. USART_STS register followed by a USART_DT read operation)<br>0: No framing error is detected.<br>1: Framing error is detected. |
| Bit 0 | PERR | 0x0 | ro | Parity error<br>This bit is set by hardware when parity error occurs. It is cleared by software. USART_STS register followed by a USART_DT read operation)<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 | Kept at its default value.                                                                                                                                                                                                                                                         |
| Bit 8: 0  | DT       | 0x00        | 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 the TEN and REN are both disabled, the baud counter stops counting.

| Bit        | Name     | Reset value | Type | Description                                     |
|------------|----------|-------------|------|-------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                      |
| Bit 15: 0  | DIV      | 0x0000      | rw   | Divider<br>This field define the USART divider. |

## 12.12.4 Control register 1 (USART\_CTRL1)

| Bit         | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                  |
|-------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 29  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                   |
| Bit 28      | DBN1     | 0x0         | rw   | Data bit num<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 27: 26  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                   |
| Bit 25 : 21 | TSDT     | 0x00        | rw   | 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 to switch back to transmit. This time depends on the TSDT value, in unit of 1/16 baud rate. |
| Bit 20 : 16 | TCDT     | 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: 14 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 13     | UEN      | 0x0 | rw   | USART enable<br>0: USART is disabled.<br>1: USART is enable.                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 12     | DBN0     | 0x0 | rw   | Data bit num<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.                                                                                                                                                                                                                                                                                       |
| Bit 11     | WUM      | 0x0 | rw   | Wakeup mode<br>This bit determines the way to wake up silent mode.<br>0: Waken up by idle line<br>1: Waken up by ID match                                                                                                                                                                                                                                                                                                                                               |
| Bit 10     | PEN      | 0x0 | rw   | Parity enable<br>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: Parity control is disabled.<br>1: Parity control is enabled.                                                                                 |
| Bit 9      | PSEL     | 0x0 | rw   | Parity selection<br>This bit selects the odd or even parity after the parity control is enabled.<br>0: Even parity<br>1: Odd parity                                                                                                                                                                                                                                                                                                                                     |
| Bit 8      | PERRIEN  | 0x0 | rw   | PERR interrupt enable<br>0: Interrupt is disabled.<br>1: Interrupt is enabled.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 7      | TDBEIEN  | 0x0 | rw   | TDBE interrupt enable<br>0: Interrupt is disabled.<br>1: Interrupt is enabled.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 6      | TDCIEN   | 0x0 | rw   | TDC interrupt enable<br>0: Interrupt is disabled.<br>1: Interrupt is enabled.                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 5      | RDBFIEN  | 0x0 | rw   | RDBF interrupt enable<br>0: Interrupt is disabled.<br>1: Interrupt is enabled.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 4      | IDLEIEN  | 0x0 | rw   | IDLE interrupt enable<br>0: Interrupt is disabled.<br>1: Interrupt is enabled.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 3      | TEN      | 0x0 | rw   | Transmitter enable<br>This bit enables the transmitter.<br>0: Transmitter is disabled.<br>1: Transmitter is enabled.                                                                                                                                                                                                                                                                                                                                                    |
| Bit 2      | REN      | 0x0 | rw   | Receiver enable<br>This bit enables the receiver.<br>0: Receiver is disabled.<br>1: Receiver is enabled.                                                                                                                                                                                                                                                                                                                                                                |
| Bit 1      | RM       | 0x0 | rw   | Receiver mute<br>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. |

|       |     |     |    |                                                                                                                                                                                                                                                                                    |
|-------|-----|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 | SBF | 0x0 | rw | Send break frame<br>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: 16 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                   |
| 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: LIN mode is disabled.<br>1: LIN mode is enabled.                                                                                                                                                                                                                                       |
| Bit 13: 12 | STOPBN   | 0x0         | rw   | STOP bit num<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: Clock is disabled.<br>1: Clock is 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.<br>0: The clock pulse of the last data bit is no output on the clock pin.<br>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 num<br>This bit is used to select 11-bit or 10-bit break frame.<br>0: 10-bit break frame<br>1: 11-bit break frame                                                                                                                                                                            |
| Bit 4      | IDBN     | 0x0         | rw   | Identification bit num<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 or 8-bit data mode, the ID bit number is the lower 6, 7 or 8 bit, respectively. If the                                                                         |

|          |     |     |    |                                                                                               |
|----------|-----|-----|----|-----------------------------------------------------------------------------------------------|
|          |     |     |    | parity check is enabled, the ID bit number is then 5, 6 or 7 bits.                            |
| Bit 3: 0 | IDL | 0x0 | rw | USART identification<br>This field holds the lower four bits of USART ID. It 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 | 0x0000      | resd | Forced 0 by hardware.                                                                                                                                                                                                                                                                                                                                   |
| Bit 15      | DEP      | 0x0         | rw   | DE polarity selection<br>0: High level active<br>1: Low level active                                                                                                                                                                                                                                                                                    |
| Bit 14      | RS485EN  | 0x0         | 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 13 : 11 | Reserved | 0x0         | resd | Forced 0 by hardware.                                                                                                                                                                                                                                                                                                                                   |
| Bit 10      | CTSCFIEN | 0x0         | rw   | CTSCFIEN interrupt enable<br>0: CTSCFIEN interrupt disabled<br>1: CTSCFIEN interrupt enabled                                                                                                                                                                                                                                                            |
| Bit 9       | CTSEN    | 0x0         | rw   | CTS enable<br>0: CTS is disabled.<br>1: CTS is enabled.                                                                                                                                                                                                                                                                                                 |
| Bit 8       | RTSEN    | 0x0         | rw   | RTS enable<br>0: RTS is disabled.<br>1: RTS is enabled.                                                                                                                                                                                                                                                                                                 |
| Bit 7       | DMATEN   | 0x0         | rw   | DMA transmitter enable<br>0: DMA transmitter is disabled.<br>1: DMA transmitter is enabled.                                                                                                                                                                                                                                                             |
| Bit 6       | DMAREN   | 0x0         | rw   | DMA receiver enable<br>0: DMA receiver is disabled.<br>1: DMA receiver is enabled.                                                                                                                                                                                                                                                                      |
| Bit 5       | SCMEN    | 0x0         | rw   | Smartcard mode enable<br>0: Smartcard mode is disabled.<br>1: Smartcard mode is enabled.                                                                                                                                                                                                                                                                |
| Bit 4       | SCNACKEN | 0x0         | rw   | Smartcard NACK enable<br>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.                                                                                                                                                                       |
| Bit 3       | SLBEN    | 0x0         | rw   | Single-wire bidirectional half-duplex enable<br>0: Single-wire bidirectional half-duplex is disabled.<br>1: Single-wire bidirectional half-duplex is enabled.                                                                                                                                                                                           |
| Bit 2       | IRDALP   | 0x0         | rw   | IrDA low-power mode<br>This bit is used to configure IrDA low-power mode.<br>0: IrDA low-power mode is disabled.<br>1: IrDA low-power mode is enabled.                                                                                                                                                                                                  |
| Bit 1       | IRDAEN   | 0x0         | rw   | IrDA enable<br>0: IrDA is disabled.<br>1: IrDA is enabled.                                                                                                                                                                                                                                                                                              |
| Bit 0       | ERRIEN   | 0x0         | rw   | Error interrupt enable<br>An interrupt is generated when a framing error, overflow error or noise error occurs.<br>0: Error interrupt is disabled.<br>1: Error interrupt is enabled.                                                                                                                                                                    |

## 12.12.7 Guard time and divider register (USART\_GDIV)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Forced 0 by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 15: 8  | SCGT     | 0x00        | rw   | <p>Smartcard guard time value</p> <p>This field specifies the guard time value. The transmission complete flag is set after this guard time in smartcard mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 7: 0   | ISDIV    | 0x00        | rw   | <p>IrDA/smartcard division</p> <p>In IrDA mode:</p> <p>8 bit [7: 0] is valid. It is valid 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;</p> <p>00000000: Reserved–Do not write.</p> <p>00000001: Divided by 1</p> <p>00000010: Divided by 2</p> <p>.....</p> <p>Smartcard mode:</p> <p>The lower 5 bit [4: 0] is valid. This division is used to divide the peripheral clock to provide clock for the Smartcard.</p> <p>Configured as follows:</p> <p>00000: Reserved–Do not write.</p> <p>00001: Divided by 2</p> <p>00010: Divided by 4</p> <p>00011: Divided by 6</p> <p>.....</p> |

# 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 an introduction of the main features and configuration procedure of SPI used as SPI or I<sup>2</sup>S.

## 13.2 Function overview

### 13.2.1 SPI description

The SPI can be configured as host or slave based on software configuration, supporting full-duplex, reception-only full-duplex and transmission-only/reception-only half-duplex modes, DMA transfer, and automatic CRC function of SPI internal hardware. In the meantime, the SPI interface can be compatible with the TI protocol through software configurations.

#### SPI block diagram:

Figure 13-1 SPI block diagram



#### Main features as SPI:

- Full-duplex or half-duplex communication
  - Full-duplex synchronous communication (supporting reception-only mode to release IO for transmission)
  - Half-duplex synchronous communication (transfer direction is configurable: receive or transmit)
- Master or slave mode
- CS signal processing mode
  - CS signal processing by hardware
  - CS signal processing by software
- 8-bit or 16-bit frame format
- Communication frequency and prescalers (prescalers 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 using DMA
- Support hardware CRC transmission and error checking
- 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 selector

When used as an SPI interface, it supports 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 bit and the ORA bit is both 0. In this case, the SPI supports data transmission and reception at the same time. IO connection is as follows:

Figure 13-3 SPI two-wire unidirectional full-duplex connection



In either master or 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 is 0 and the ORA is set. In this case, the SPI can be used only for data reception (transmission is not supported). The MISO pin transmits data in slave mode and receives data in master mode. The MOSI pin transmits data in master mode and receives data in slave mode.

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 master mode, it is necessary to wait until the second-to-last RDBF bit is set and then another SPI\_CPK period before disabling the SPI. The last RDBF must be set 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 required to wait until the BF becomes 0 before entering power-saving mode.

#### Figure 13-6 shows single-wire bidirectional half-duplex mode and SPI IO connection

When the SLBEN is set, 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 or receives data in master mode, while the MISO pin is released. In slave mode, the MISO pin transmits or receives data, but the MOSI pin is released.

The SLBDT bit is used by software to configure transfer direction. When the SLBDT bit is set, the SPI can be used only for data transmission; when the SLBDT bit is 0, the SPI can be used only for data reception.

Figure 13-6 Single-wire bidirectional half-duplex mode



When the SPI is selected for data transmission in single-wire bidirectional half-duplex mode (master or slave), 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 another SPI\_SCK period before disabling the SPI. And the last RDBF must be set 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 flags 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 the data lines by enabling the SCK signal output followed by CS signal. The hardware and software configuration procedure is detailed as follows, along with their respective input/output in master and slave mode.

#### CS hardware configuration procedure:

In master mode with CS being as an output, HWCSOE=1, SWCSEN=0, the CS hardware control is enabled. 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, HWCSOE=0, SWCSEN=0, the CS hardware control is enabled. 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 at the same time. An interrupt is generated if ERRIE=1. When the MMERR is 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 operation to the SPI\_CTRL1 register.

In slave mode with CS being as an input, HWCSOE=0, SWCSEN=0, the CS hardware control is enabled. The slave selects 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.

#### CS software configuration procedure:

In master mode with CS being as an input, SWCSEN=1, the CS software control is enabled. When SWCSIL=0, the SPI is automatically disabled by hardware and enters slave mode. The mode error flag (MMERR bit) is set at this time. An interrupt is generated if ERRIE=1. 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 operation 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 required to generate a communication clock for data reception and transmission on the SPI, 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 via IO. In all, the SPI\_SCK controller is used for the generation and distribution of SPI\_SCK, with the configuration procedure detailed as follows:

#### SPI\_SCK controller configuration procedure:

- Clock polarity and clock phase selection: It is selected by setting the CLKPOL and CLKPHA bit.
- Clock prescaler selection: Select the desired PCLK frequency by setting the CRM bit. Select the desired prescaler by setting the MDIV[3: 0] bit.
- Master/slave selection: Select SPI as master or slave 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 output until when the SPI is disabled and the reception is complete.

### 13.2.5 CRC

There is an independent transmission and reception CRC calculation unit in the SPI. When used as SPI through software configuration, the SPI enables CRC calculation and CRC check automatically while the user is reading or writing through DMA or CPU. During the transmission, if the received data is not consistent with, detected by hardware, the data in the SPI\_RCRC register, and such data is exactly the CRC value, then the CCERR bit will be set. An interrupt is generated if ERRIE=1.

The CRC function and configuration procedure of the SPI are described as follows.

#### CRC configuration procedure

- CRC calculation polynomial is configured by setting the SPI\_CPOLY register.
- CRC enable: The CRC calculation is enabled 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 result is regarded as the value of the SPI\_TCRC register.

#### Reception using DMA

When DMA is used to read the data to be received, 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 of the SPI\_RCRC register. If check error occurs, the CCERR flag is set. An interrupt is generated if the ERRIE bit is enabled.

#### Transmission using CPU

Unlike DMA mode, after writing the last data to be transmitted, the CPU mode requires the NTC bit to be set by software before the end of the last data transmission.

#### Reception using CPU

In two-wire unidirectional full-duplex mode, follow CPU transmission mode to operate the NTC bit, the CRC calculation and check in CPU reception mode will be completed automatically.

In single-wire unidirectional reception-only mode and single-wire bidirectional reception-only mode, it is required to set the NTC bit before the software receives the last data when the second-to-last data is received.

### 13.2.6 DMA transfer

The SPI supports write and read operations with DMA. Refer to the following configuration procedure.

Special attention should be paid to: when the CRC calculation and check is enabled, the number of data transferred by DMA is configured as the number of the data to be transferred. The number of data read with DMA is configured as the number of the data to be received. In this case, the hardware will send CRC automatically at the end of full transfer, and the receiver will also perform CRC check. Note that the received CRC data will be moved into the SPI\_DT register by hardware, with the RDBF being set, and the DMA read request will be sent if then DAM transfer is enabled. Hence, it is recommended to read the SPI\_DT register to get the CRC value at the end of CRC reception in order to avoid the upcoming transfer error.

#### Transmission with DMA

- Select DMA channel: Select a DMA channel for the current SPI transfer from DMA flexible request 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 DMA transfer channel: Select a DMA channel for the current SPI from DMA flexible request 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

The SPI interface is compatible with the TI protocol. The TI mode is enabled by setting the TIEN bit.

In this mode, the SPI interface will generate 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.

In slave mode, once the TI mode is enabled, the SPI slave controls the MISO pin only during data transmission, meaning that the MISO pin state remains Hi-Z in idle state.

In slave mode, once the TI mode is enabled, 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 pulse error will be discarded 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 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 available in the SPI that 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. If the TDBEIE bit is set, an interrupt is generated. After the data is written, the TDBE is pulled low until the data is moved to the transmit data buffer before the TDBE is set once again. This means 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 for data transmission. 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 specific 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 procedure are as follows.

#### Transmitter configuration procedure:

- 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 output 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, the data is moved from the shift register to the receive data buffer

register. Then the transmitter sets the receive data complete flag to the SPI logic. When the flag is detected by the SPI logic, the data in the receive data buffer is copied into the SPI\_DT register, with the RDBF being set. This means that the data is received, and it is already stored into the SPI\_DT. In this case, read access to 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 RDBE bit. The reset value of this bit is 0, indicating that the SPI\_DT register is empty. If the data is received and moved into the SPI\_DT, the RDBF is set, meaning that there are some data to be read in the SPI\_DT register. 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, if the previous received data is still not read (RDBF=1), then the data overflow occurs. The previous receive data is not lost, but the next received data will do. At this point, the ROERR is set. An interrupt is generated if the ERRIE is set. Read SPI\_DT register and then the SPI\_STS register will clear the ROERR bit. The recommended configuration procedure is as follows.

#### Receiver configuration procedure:

- 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 (RDBEIE =1) through the RDBE 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 communication timings, which includes full-duplex and half-duplex master/slave timings.

#### Full-duplex communication – master mode

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 frame

Master transmit (MOSI): 0xaa, 0xcc, 0xaa

Slave transmit (MISO): 0xcc, 0xaa, 0xcc

Figure 13-7 Master full-duplex communications



#### Full-duplex communication – slave mode

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 frame

Master transmit (MOSI): 0xaa, 0xcc, 0xaa

Slave transmit (MISO): 0xcc, 0xaa, 0xcc

Figure 13-8 Slave full-duplex communications



### Half-duplex communication – master transmit

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 frame

Master transmit (MOSI): 0xaa, 0xcc, 0xaa

Figure 13-9 Master half-duplex transmit



### Half-duplex communication – slave receive

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 frame

Slave receive: 0xaa, 0xcc, 0xaa

Figure 13-10 Slave half-duplex receive



### Half-duplex communication – slave transmit

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 frame

Slave transmit: 0xaa, 0xcc, 0xaa

Figure 13-11 Slave half-duplex transmit



### Half-duplex communication – master receive

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 frame

Master receive: 0xaa, 0xcc, 0xaa

Figure 13-12 Master half-duplex receive



### 13.2.11 TI mode

The SPI interface supports TI mode. The TIEN bit can be set to enable SPI TI mode.

In TI mode, a bit of different is present between continuous and discontinuous communication timings. When the to-be transmitted 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-13 TI mode continuous transfer



When the to-be-transmitted data is written between the rising and falling SCK edge corresponding to the last data of the current transmit frame, a dummy CLK exists between data.

Figure 13-14 TI mode continuous transfer with dummy CLK



Figure 13-15 TI mode discontinuous transfer



When the to-be-transmitted 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. If the slave still does not detect a valid CS pulse at the end of the current data reception, it disables MISO output after 1/2T SCK + 3T PCLK to control MISO floating.

Figure 13-16 TI mode SCK and slave MISO release



## 13.2.12 Interrupts

Figure 13-17 SPI interrupts



### 13.2.13 IO pin control

Usually, the SPI is connected to external devices through four pins.

- MISO: Master In/Slave Out. The pin receives data in master mode, and transmits data in slave mode.
- MOSI: Master Out/Slave In. The pin transmits data in master mode, and receives data in slave mode.
- SCK: SPI communication clock. The pin serves as output in master mode, and input in slave mode.
- CS: Chip Select. This is an optional pin which selects master/slave mode.

*Note: Some of SPI1/I<sup>2</sup>S1 and SPI3/I<sup>2</sup>S3 are shared with JTAG pins (SPIx\_CS/I2Sx\_WS shared with JTDI, SPIx\_SCK/I2Sx\_CK with JTDO), so these pins are not controlled by IO controller, and they are used as JTAG by default after each reset. To configure them as SPIx/I<sup>2</sup>Sx, the JTAG should be disabled (during debugging) and switched to SWD interface, or both the JTAG and SWD are disabled (during normal run)*

### 13.2.14 Precautions

- CRC value is obtained by software reading DT register at the end of CRC reception
- In the case of CPOL=1 and CPHA=1, the clock divided by 3 that is generated inside the SPI must be less than 32 MHz. To achieve a greater communication frequency, it is necessary to use a clock divided by 2, and adjust the corresponding HCLK and PCLK frequencies. The SPI frequencies must not exceed the maximum value programmed in the corresponding datasheet.

## 13.3 I<sup>2</sup>S functional description

### 13.3.1 I<sup>2</sup>S introduction

The I<sup>2</sup>S can be configured by software as master reception/transmission, and slave reception/transmission, supporting four kinds of audio protocols including Philips standard, MSB-aligned standard, LSB-aligned standard and PCM standard, respectively. The DMA transfer is also supported.

A single I<sup>2</sup>S supports half-duplex. However, it can work with two additional instantiated I<sup>2</sup>S modules (I<sup>2</sup>S2EXT and I<sup>2</sup>S3EXT) to achieve full-duplex mode. In other words, combining the I<sup>2</sup>S2 with the I<sup>2</sup>S2EXT enables the I<sup>2</sup>S2 to support full-duplex mode. This is true for the I<sup>2</sup>S3 through the combination of the I<sup>2</sup>S3 with the I<sup>2</sup>S3EXT. Refer to I<sup>2</sup>S full-duplex section for more information.

Figure 13-18 I<sup>2</sup>S block diagram



### Main features when the SPI is used as I<sup>2</sup>S:

- Programmable operation mode
  - 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 bist, 24 bits, 32 bits)
- Programmable channel bits (16 bits, 32 bits)
- Programmable audio protocol
  - I<sup>2</sup>S Philips standard
  - MSB-aligned standard (left-aligned)
  - LSB-aligned standard (right-aligned)
  - PCM standard (long or short frame)
- 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

Two extra I<sup>2</sup>S modules (I<sup>2</sup>S2EXT and I<sup>2</sup>S3EXT) are used to support I<sup>2</sup>S full-duplex mode. Combine the I<sup>2</sup>S2 with the I<sup>2</sup>S2EXT, and I<sup>2</sup>S3 with I<sup>2</sup>S3EXT to support full-duplex mode.

*Note: I<sup>2</sup>S2EXT and I<sup>2</sup>S3EXT only used for I<sup>2</sup>S full-duplex mode.*

Figure 13-19 I<sup>2</sup>S full-duplex structure



I<sup>2</sup>Sx can be used as master, where x should be 2 or 3

- In half-duplex mode, only I<sup>2</sup>Sx can output SCK and WS
- In full-duplex mode, only I<sup>2</sup>Sx can output SCK and WS

I<sup>2</sup>SxEXT is only used for full-duplex mode, and I<sup>2</sup>SxEXT only for slave mode

Both the I<sup>2</sup>Sx and I<sup>2</sup>SxEXT can be configured as transmit or receive mode.

### 13.3.3 Operating mode selector

The SPI, used as I<sup>2</sup>S selector, offers multiple operating modes for selection, namely, slave device transmission, slave device reception, master device transmission and master device reception. 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-20 I<sup>2</sup>S slave device transmission**Slave device reception:**

Set the I<sup>2</sup>SMSEL bit, and OPERSEL[1:0]=01, the I<sup>2</sup>S will work in slave device reception mode.

Figure 13-21 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-22 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-23 I<sup>2</sup>S master device reception

### 13.3.4 Audio protocol selector

While being used as I<sup>2</sup>S, the SPI supports multiple audio protocols. The user can control the audio protocol selector through software configuration to select the desired audio protocol, with the data bits and channel bits being controlled by the audio protocol selector. Besides, the user can also select the data bits and channel bits through software configuration. Meanwhile, the audio protocol selector manages the WS controller, output or detect the WS signal that meets 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 data bits by setting the I2SDBN bit

I2SDBN=00: 16 bits

I2SDBN =01: 24 bits

I2SDBN =10: 32 bits

- Select 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 protocols, 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 bit is the same as the channel bit. Each channel requires 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 bit is different from the channel bit. Each channel requires one read/write operation from/to the SPI\_DT register, and the number of DMA transfer is 1. The first 16 bits (MSB) are the significant bits, and the 16-bit LSB is forced to 0 by hardware.

- Philips standard, PCM standard or MSB-aligned standard, 24-bit data and 32-bit channel

The data bit is different from the channel bit. Each channel requires two read/write operations from/to the SPI\_DT register, and the number of DMA transfer is 2. The 16-bit MSB transmits and receives the first 16-bit data, the 16-bit LSB transmits and receives the 8-bit MSB data, with 8-bit LSB data being forced to 0 by hardware.

- Philips standard, PCM standard, MSB-aligned or LSB-aligned standard, 32-bit data and 32-bit channel

The data bit is the same as the channel bit. 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 in two times, with 16-bit data each time.

- LSB-aligned standard, 16-bit data and 32-bit channel

The data bit is different from the channel bit. Each channel requires one read/write operation from/to the SPI\_DT register, and the number of DMA transfer is 1. The 16 bits (LSB) are the significant bits 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 bit is different from the channel bit. Each channel requires two read/write operations from/to the SPI\_DT register, and the number of DMA transfer is 2. For the first 16-bit data, its 8-bit LSB are the significant bits, with the 8-bit MSB forced to 0 by hardware; the subsequent 16 bits transmit and receive the second 16-bit data.

### 13.3.5 I2S\_CLK controller

The audio protocols the SPI supports adopts synchronous transmission. In master mode, it is required to generate a communication clock for data reception and transmission on the SPI, 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, with the configuration procedure detailed as follows:

When used as I2S master, the SPI can provide communication clock (CK) and main peripheral clock (MCK) shown in Figure 13-24. The CK and MCK are generated by HCLK divider, with the prescaler of the MCK determined by I2SDIV and I2SODD. The calculation formula is seen in Figure 13-24.

The prescaler of the CK depends on whether to provide the main clock for peripherals. To ensure that the main clock is always 256 times larger than the audio sampling frequency, the channel bits should be taken into account. When the main clock is needed, the CK should be divided by 8 (I2SCBN=0) or 4 (I2SCBN=1), then divided again by the same prescaler as that of the MCK, that is the final communication clock; When the main clock is not needed, the prescaler of the CK is determined by I2SDIV and I2SODD, shown in Figure 13-24.

Figure 13-24 CK & MCK source in master mode



Apart from the above-mentioned 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

| SysCLK<br>(MHz) | MCL<br>K | Target<br>Fs<br>(Hz) | 16-bit     |         |          |        | 32-bit     |         |          |        |
|-----------------|----------|----------------------|------------|---------|----------|--------|------------|---------|----------|--------|
|                 |          |                      | I2S<br>DIV | I2S_ODD | RealFs   | Error  | I2S<br>DIV | I2S_ODD | RealFs   | Error  |
| 240             | NO       | 192000               | 19         | 1       | 192307   | 1.2%   | 10         | 0       | 187500   | 2.34%  |
| 240             | NO       | 96000                | 39         | 0       | 96153    | 0.16%  | 19         | 1       | 96153    | 0.16%  |
| 240             | NO       | 48000                | 78         | 0       | 48076    | 0.16%  | 39         | 0       | 48076    | 0.16%  |
| 240             | NO       | 44100                | 85         | 0       | 44117    | 0.04%  | 42         | 1       | 44117    | 0.04%  |
| 240             | NO       | 32000                | 117        | 0       | 32051    | 0.16%  | 58         | 1       | 32051    | 0.16%  |
| 240             | NO       | 22050                | 170        | 0       | 22058    | 0.04%  | 85         | 0       | 22058    | 0.04%  |
| 240             | NO       | 16000                | 234        | 1       | 15991    | 0.05%  | 117        | 0       | 16025    | 0.16%  |
| 240             | NO       | 11025                | 340        | 0       | 11029    | 0.04%  | 170        | 0       | 11029    | 0.04%  |
| 240             | NO       | 8000                 | 469        | 0       | 7995     | 0.05%  | 234        | 1       | 7995     | 0.05%  |
| 240             | YES      | 192000               | 2          | 1       | 187500   | 2.34%  | 2          | 1       | 187500   | 2.34%  |
| 240             | YES      | 96000                | 5          | 0       | 93750    | 2.34%  | 5          | 0       | 93750    | 2.34%  |
| 240             | YES      | 48000                | 10         | 0       | 46875    | 2.34%  | 10         | 0       | 46875    | 2.34%  |
| 240             | YES      | 44100                | 10         | 1       | 44642    | 1.23%  | 10         | 1       | 44642    | 1.23%  |
| 240             | YES      | 32000                | 14         | 1       | 32327    | 1.02%  | 14         | 1       | 32327    | 1.02%  |
| 240             | YES      | 22050                | 21         | 1       | 21802    | 1.12%  | 21         | 1       | 21802    | 1.12%  |
| 240             | YES      | 16000                | 29         | 1       | 15889    | 0.68%  | 29         | 1       | 15889    | 0.68%  |
| 240             | YES      | 11025                | 42         | 1       | 11029    | 0.04%  | 42         | 1       | 11029    | 0.04%  |
| 240             | YES      | 8000                 | 58         | 1       | 8012     | 0.16%  | 58         | 1       | 8012     | 0.16%  |
| 200             | No       | 192000               | 16         | 1       | 189393.9 | 1.36%  | 8          | 0       | 195312.5 | 1.73%  |
| 200             | No       | 96000                | 32         | 1       | 96153.85 | 0.16%  | 16         | 1       | 94696.97 | 1.36%  |
| 200             | No       | 48000                | 65         | 0       | 48076.92 | 0.16%  | 32         | 1       | 48076.92 | 0.16%  |
| 200             | No       | 44100                | 71         | 0       | 44014.08 | 0.19%  | 35         | 1       | 44014.08 | 0.19%  |
| 200             | No       | 32000                | 97         | 1       | 32051.28 | 0.16%  | 49         | 0       | 31887.76 | 0.35%  |
| 200             | No       | 22050                | 141        | 1       | 22084.81 | 0.16%  | 71         | 0       | 22007.04 | 0.19%  |
| 200             | No       | 16000                | 195        | 1       | 15984.65 | 0.10%  | 97         | 1       | 16025.64 | 0.16%  |
| 200             | No       | 11025                | 283        | 1       | 11022.93 | 0.02%  | 141        | 1       | 11042.4  | 0.16%  |
| 200             | No       | 8000                 | 390        | 1       | 8002.561 | 0.03%  | 195        | 1       | 7992.327 | 0.10%  |
| 200             | Yes      | 192000               | 3          | 0       | 130208.3 | 32.18% | 3          | 0       | 130208.3 | 32.18% |
| 200             | Yes      | 96000                | 4          | 0       | 97656.25 | 1.73%  | 4          | 0       | 97656.25 | 1.73%  |
| 200             | Yes      | 48000                | 8          | 0       | 48828.13 | 1.73%  | 8          | 0       | 48828.13 | 1.73%  |
| 200             | Yes      | 44100                | 9          | 0       | 43402.78 | 1.58%  | 9          | 0       | 43402.78 | 1.58%  |
| 200             | Yes      | 32000                | 12         | 0       | 32552.08 | 1.73%  | 12         | 0       | 32552.08 | 1.73%  |
| 200             | Yes      | 22050                | 17         | 1       | 22321.43 | 1.23%  | 17         | 1       | 22321.43 | 1.23%  |
| 200             | Yes      | 16000                | 24         | 1       | 15943.88 | 0.35%  | 24         | 1       | 15943.88 | 0.35%  |
| 200             | Yes      | 11025                | 35         | 1       | 11003.52 | 0.19%  | 35         | 1       | 11003.52 | 0.19%  |
| 200             | Yes      | 8000                 | 49         | 0       | 7971.939 | 0.35%  | 49         | 0       | 7971.939 | 0.35%  |
| 100             | No       | 192000               | 8          | 0       | 195312.5 | 1.73%  | 4          | 0       | 195312.5 | 1.73%  |
| 100             | No       | 96000                | 16         | 1       | 94696.97 | 1.36%  | 8          | 0       | 97656.25 | 1.73%  |
| 100             | No       | 48000                | 32         | 1       | 48076.92 | 0.16%  | 16         | 1       | 47348.48 | 1.36%  |
| 100             | No       | 44100                | 35         | 1       | 44014.08 | 0.19%  | 17         | 1       | 44642.86 | 1.23%  |
| 100             | No       | 32000                | 49         | 0       | 31887.76 | 0.35%  | 24         | 1       | 31887.76 | 0.35%  |
| 100             | No       | 22050                | 71         | 0       | 22007.04 | 0.19%  | 35         | 1       | 22007.04 | 0.19%  |
| 100             | No       | 16000                | 97         | 1       | 16025.64 | 0.16%  | 49         | 0       | 15943.88 | 0.35%  |
| 100             | No       | 11025                | 141        | 1       | 11042.4  | 0.16%  | 71         | 0       | 11003.52 | 0.19%  |
| 100             | No       | 8000                 | 195        | 1       | 7992.327 | 0.10%  | 97         | 1       | 8012.821 | 0.16%  |
| 100             | Yes      | 96000                | 2          | 0       | 97656.25 | 1.73%  | 2          | 0       | 97656.25 | 1.73%  |
| 100             | Yes      | 48000                | 4          | 0       | 48828.13 | 1.73%  | 4          | 0       | 48828.13 | 1.73%  |

|     |     |        |     |   |          |        |    |   |          |        |
|-----|-----|--------|-----|---|----------|--------|----|---|----------|--------|
| 100 | Yes | 44100  | 4   | 1 | 43402.78 | 1.58%  | 4  | 1 | 43402.78 | 1.58%  |
| 100 | Yes | 32000  | 6   | 0 | 32552.08 | 1.73%  | 6  | 0 | 32552.08 | 1.73%  |
| 100 | Yes | 22050  | 9   | 0 | 21701.39 | 1.58%  | 9  | 0 | 21701.39 | 1.58%  |
| 100 | Yes | 16000  | 12  | 0 | 16276.04 | 1.73%  | 12 | 0 | 16276.04 | 1.73%  |
| 100 | Yes | 11025  | 17  | 1 | 11160.71 | 1.23%  | 17 | 1 | 11160.71 | 1.23%  |
| 100 | Yes | 8000   | 24  | 1 | 7971.939 | 0.35%  | 24 | 1 | 7971.939 | 0.35%  |
| 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 write and read operations with DMA. 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 DMA channel: 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 DMA transfer channel: 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 being 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 is responsible for sending and receiving the desired data frame according to the configuration of the communication controller. Thus their 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 operation linked to CRC, including CCERR flag and the corresponding interrupts, is 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 periods 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 period before the I<sup>2</sup>S.
  - I2SDBN, I2SCBN,STDSLE combination: wait for the second-to-last RDBF=1 and one CK period before disabling the I<sup>2</sup>S.

#### I<sup>2</sup>S transmitter configuration procedure:

- Configure operation mode selector
- Configure audio protocol selector
- Configure I<sup>2</sup>S\_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 procedure:

- Configure operation mode selector
- Configure audio protocol selector
- Configure I<sup>2</sup>S\_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 most significant byte (left-aligned) and the least significant byte (right-aligned) standards, and the PCM standard. Figure 13-23 shows their respective timings.

Figure 13-25 Audio standard timings



### 13.3.9 Interrupts

Figure 13-26 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 need to provide main clock for peripherals. The I<sup>2</sup>S shares some pins with the 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_I2SCLKP | 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] bit is in the SPI_CTRL2 register, 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<br>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 0 by hardware.                                                                                                                                                            |
| Bit 9      | MDIV3EN  | 0x0         | rw   | Master clock frequency divided by 3 enable<br>0: Disabled<br>1: Enabled<br>Note: When this bit is set, the MDIV[3: 0] becomes invalid, and the SPI clock is forced to be PCLK/3. |
| 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, TUERR and CSPAS)<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>Note: This mode is not used in I <sup>2</sup> S mode. It must be 0 in                   |

|       |          |     |      |                                                                                                                                                                                                                                            |
|-------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | I2S mode.                                                                                                                                                                                                                                  |
| Bit 3 | Reserved | 0x0 | resd | Kept at its default value                                                                                                                                                                                                                  |
| Bit 2 | HWCSEOE  | 0x0 | rw   | <p>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.</p> <p>0: Disabled<br/>1: Enabled</p> |
| Bit 1 | DMATEN   | 0x0 | rw   | <p>DMA transmit enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                  |
| Bit 0 | DMAREN   | 0x0 | rw   | <p>DMA receive enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                   |

### 13.4.3 SPI status register (SPI\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 9 | Reserved | 0x00        | resd | Forced 0 by hardware                                                                                                                                                                                                               |
| Bit 8     | CSPAS    | 0x0         | ro   | <p>CS pulse abnormal setting flag<br/>0: CS pulse flag normal<br/>1: CS pulse flag is set abnormally</p> <p>Note: This bit is used for TI slave mode. It is cleared by reading the STS register.</p>                               |
| Bit 7     | BF       | 0x0         | ro   | <p>Busy flag<br/>0: SPI is not busy.<br/>1: SPI is busy.</p>                                                                                                                                                                       |
| Bit 6     | ROERR    | 0x0         | ro   | <p>Receiver overflow error<br/>0: No overflow error<br/>1: Overflow error occurs.</p>                                                                                                                                              |
| Bit 5     | MMERR    | 0x0         | ro   | <p>Master mode error<br/>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.</p> |
| Bit 4     | CCERR    | 0x0         | rw0c | <p>CRC error<br/>Set by hardware, and cleared by software.<br/>0: No CRC error<br/>1: CRC error occurs.</p>                                                                                                                        |
| Bit 3     | TUERR    | 0x0         | ro   | <p>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.</p> <p>Note: This bit is only used in I<sup>2</sup>S mode.</p>   |
| Bit 2     | ACS      | 0x0         | ro   | <p>Audio channel state<br/>This bit indicates the status of the current audio channel.<br/>0: Left channel<br/>1: Right channel</p> <p>Note: This bit is only used in I<sup>2</sup>S mode.</p>                                     |
| Bit 1     | TDBE     | 0x1         | ro   | <p>Transmit data buffer empty<br/>0: Transmit data buffer is not empty.<br/>1: Transmit data buffer is empty.</p>                                                                                                                  |
| Bit 0     | RDBF     | 0x0         | ro   | Receive data buffer full                                                                                                                                                                                                           |

0: Transmit data buffer is not full.

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. 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. 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 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                       |

|          |           |     |      |                                                                                                                                                                                                        |
|----------|-----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |           |     |      | 1: Long frame synchronization<br>Kept at its default value                                                                                                                                             |
| Bit 6    | Reserved  | 0x0 | resd | I <sup>2</sup> S standard select<br>00: Philips standard                                                                                                                                               |
| Bit 5: 4 | STDSEL    | 0x0 | rw   | 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 |

### 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 Timer

AT32F435 timers include basic timers, general-purpose timers, and advanced timers.

Please refer to Section 14.1 ~ Section 14.4 for the detailed function modes. All functions of different timers are shown in the following tables.

Table 14-1 TMR functional comparison

| Timer type             | Timer | Counter bit | Count mode | Repetition | Prescaler | DMA requests | Capture/compare channel | PWM input mode | EXT input | Brake input |
|------------------------|-------|-------------|------------|------------|-----------|--------------|-------------------------|----------------|-----------|-------------|
| Advanced-control timer | TMR1  |             | Up         |            |           |              |                         |                |           |             |
|                        | TMR8  | 16          | Down       | 16-bit     | 1~65535   | O            | 4                       | O              | O         | O           |
|                        | TMR20 |             | Up/Down    |            |           |              |                         |                |           |             |
| General-purpose timer  | TMR2  | 16/32       | Up         |            |           |              |                         |                |           |             |
|                        | TMR5  |             | Down       | X          | 1~65535   | O            | 4                       | O              | O         | X           |
|                        | TMR3  |             | Up         |            |           |              |                         |                |           |             |
|                        | TMR4  | 16          | Down       | X          | 1~65535   | O            | 4                       | O              | O         | X           |
|                        | TMR9  |             | Up/Down    |            |           |              |                         |                |           |             |
|                        | TMR12 | 16          | Up         | X          | 1~65535   | X            | 2                       | O              | X         | X           |
|                        | TMR10 |             |            |            |           |              |                         |                |           |             |
|                        | TMR11 |             |            |            |           |              |                         |                |           |             |
|                        | TMR13 | 16          | Up         | X          | 1~65535   | X            | 1                       | X              | X         | X           |
|                        | 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 | Interfacing with hall sensors | Linkage peripheral            |
|------------------------|-------|-------------|------------|------------|---------------------|----------------------|-----------|-------------------|-------------------------------|-------------------------------|
| Advanced-control timer | TMR1  |             | Up         |            |                     |                      |           |                   |                               |                               |
|                        | TMR8  | 16          | Down       | O          | O                   | O                    | O         | O                 | O                             | Timer synchronization ADC/DAC |
|                        | TMR20 |             | Up/Down    |            |                     |                      |           |                   |                               |                               |
| General-purpose timer  | TMR2  | 16/32       | Up         |            |                     |                      |           | X                 | O                             | O                             |
|                        | TMR5  |             | Down       | O          | O                   | X                    |           | O                 | O                             | Timer synchronization ADC/DAC |
|                        | TMR3  |             | Up         |            |                     |                      |           | X                 | O                             | O                             |
|                        | TMR4  | 16          | Down       | O          | O                   | X                    |           | O                 | O                             | Timer synchronization ADC/DAC |
|                        | TMR9  |             | Up/Down    |            |                     |                      |           | X                 | X                             | X                             |
|                        | TMR12 | 16          | Up         | O          | O                   | X                    |           | X                 | X                             | Timer synchronization         |
|                        | TMR10 |             |            |            |                     |                      |           |                   |                               |                               |
|                        | TMR11 |             |            |            |                     |                      |           |                   |                               |                               |
|                        | TMR13 | 16          | Up         | O          | O                   | X                    |           | X                 | X                             | X                             |
|                        | TMR14 |             |            |            |                     |                      |           |                   |                               |                               |
| Basic timer            | TMR6  | 16          | Up         | X          | X                   | X                    |           | X                 | X                             | ADC/DAC                       |
|                        | TMR7  |             |            |            |                     |                      |           |                   |                               |                               |

## 14.1 Basic timer (TMR6 and TMR7)

### 14.1.1 TMR6 and TMR7 introduction

Each of the basic timers (TMR6 and TMR7) includes a 16-bit upcounter and the corresponding control logic. without being connected to external I/Os, they can be used for a basic timing and providing clocks for the digital-to-analog converter (DAC).

### 14.1.2 TMR6 and TMR7 main features

- 16-bit upcounter, auto reload
- 16-bit prescaler used to divide the TMR\_CLK frequency by any factor between 1 and 65536
- Synchronization circuit to trigger ADC/DAC

Figure 14-1 Basic timer block diagram



### 14.1.3 TMR6 and TMR7 function overview

#### 14.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 APB; otherwise, it doubles the APB clock frequency.

Figure 14-2 Control circuit with CK\_INT divided by 1



#### 14.1.3.2 Counting mode

The basic timer only supports upcounting mode, and it has an internal 16-bit counter.

The TMRx\_PR register is used to set the counting period. 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.

The TMRx\_DIV register is used to set the counting frequency. The counter counts once every count clock period (DIV[15:0]+1). Similar to the TMRx\_PR register, when the periodic buffer is enabled, the value in the TMRx\_DIV register is updated to the shadow register at an overflow event.

Reading the TMRx\_CNT register returns to the current counter value, and writing to the TMRx\_CNT register updates the current counter value to the value being written.

An overflow event is generated by default. Set OVFEN=1 in the TMRx\_CTRL1 to disable generation of update events. The OVFS bit in the TMRx\_CTRL1 register is used to select overflow event source. By default, counter overflow/underflow, setting OVFSWTR bit and the reset signal generated by the slave

timer controller in reset mode trigger the generation of an overflow event. When the OVFS bit is set, only counter overflow/underflow triggers an overflow event.

Setting the TMREN bit ( $\text{TMREN}=1$ ) enables the timer to start counting. Base on synchronization logic, however, the actual enable signal  $\text{TMR\_EN}$  is set 1 clock cycle after the TMREN is set.

Figure 14-3 Counter structure



### Upcounting mode

Set  $\text{TCMSEL}[1:0]=2'b00$  and  $\text{OWCDIR}=1'b0$  in the  $\text{TMRx\_CTRL1}$  register to enable upcounting mode. In this mode, the counter counts from 0 to the value programmed in the  $\text{TMRx\_PR}$  register, restarts from 0, and generates a counter overflow event, with the OVFIF bit being set to 1. If the overflow event is disabled, the counter is no longer reloaded with the preload value and period value at a counter overflow event; otherwise, the counter is updated with the preload value and period value at an overflow event.

Figure 14-4 Overflow event when  $\text{PRBEN}=0$



Figure 14-5 Overflow event when  $\text{PRBEN}=1$



Figure 14-6 Counter timing diagram with internal clock divided by 4



### 14.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. Refer to section 30.2 for details.

### 14.1.4 TMR6 and TMR7 registers

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

In Table 14-2, all the TMRx registers are mapped to a 16-bit addressable space.

Table 14-2 TMR6 and TMR7 register map and reset value

| Register   | Offset | Reset value |
|------------|--------|-------------|
| TMRx_CTRL1 | 0x00   | 0x0000      |
| TMRx_CTRL2 | 0x04   | 0x0000      |
| TMRx_IDEN  | 0x0C   | 0x0000      |
| TMRxISTS   | 0x10   | 0x0000      |
| TMRx_SWEVT | 0x14   | 0x0000      |
| TMRx_CVAL  | 0x24   | 0x0000      |
| TMRx_DIV   | 0x28   | 0x0000      |
| TMRx_PR    | 0x2C   | 0x0000      |

#### 14.1.4.1 TMR6 and TMR7 control register 1 (TMRx\_CTRL1)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 8 | Reserved | 0x00        | resd | Kept at its 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 its 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 configure overflow event or DMA request sources.<br>0: Counter overflow, setting the OVFSWTR bit or overflow event generated from the slave 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<br>- Overflow event generated from the slave controller<br>1: OEV event is disabled.<br>If the OVFSWTR bit is set, or a hardware reset is generated from the slave 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 14.1.4.2 TMR6 and TMR7 control register 2 (TMRx\_CTRL2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 7 | Reserved | 0x000       | resd | Kept at its 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: Reset<br>001: Enable<br>010: Update |
| Bit 3: 0  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                     |

#### 14.1.4.3 TMR6 and TMR7 DMA/interrupt enable register (TMRx\_IDEN)

| Bit       | Name     | Reset value | Type | Description                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------|
| Bit 15: 9 | Reserved | 0x00        | resd | Kept at its 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 its default value.                                     |
| Bit 0     | OVFIEN   | 0x0         | rw   | Overflow interrupt enable<br>0: Disabled<br>1: Enabled         |

#### 14.1.4.4 TMR6 and TMR7 interrupt status register (TMRxISTS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 1 | Reserved | 0x0000      | resd | Kept at its 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 occurs.<br>1: Overflow event occurs, and OVFEN=0, and OVFS=0 in the TMRx_CTRL1 register:<br>- An overflow event occurs when OVFG=1 in the TMRx_SWEVE register<br>- An overflow event occurs when the counter value (CVAL) is reinitialized by a trigger event. |

#### 14.1.4.5 TMR6 and TMR7 software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                       |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 1 | Reserved | 0x0000      | resd | Kept at its 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 write operation. |

#### 14.1.4.6 TMR6 and TMR7 counter value (TMRx\_CVAL)

| Bit       | Name | Reset value | Type | Description   |
|-----------|------|-------------|------|---------------|
| Bit 15: 0 | CVAL | 0x0000      | rw   | Counter value |

#### 14.1.4.7 TMR6 and TMR7 division (TMRx\_DIV)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                          |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 sent to the DIV register. |

#### 14.1.4.8 TMR6 and TMR7 period register (TMRx\_PR)

| Bit       | Name | Reset value | Type | Description                                                                                                              |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | PR   | 0x0000      | rw   | Period value<br>This indicates the period value of the TMRx counter. The timer stops working when the period value is 0. |

## 14.2 General-purpose timer (TMR2 to TMR5)

### 14.2.1 TMR2 to TMR5 introduction

The general-purpose timer (TMR2 to TMR5) consists of a 16-bit counter supporting up, down, up/down (bidirectional) counting modes, four capture/compare registers, and four independent channels to achieve input capture and programmable PWM output.

### 14.2.2 TMR2 to TMR5 main features

- Source of count clock is selectable : internal clock, external clock and internal trigger
- 16-bit up, down, up/down and encoder mode counter (TMR2/5 can be extended to 32-bit)
- 4 independent channels for input capture, output compare, PWM generation and one-pulse mode output
- Synchronization control between master and slave timers
- Interrupt/DMA is generated at overflow event, trigger event and channel event
- Support TMR burst DMA transfer

Figure 14-7 General-purpose timer block diagram



## 14.2.3 TMR2 to TMR5 functional overview

### 14.2.3.1 Counting clock

The count clock of TMR2~TMR5 can be provided by the internal clock (CK\_INT), external clock (external clock mode A and B) and internal trigger input (ISx).

Figure 14-8 Count clock



#### Internal clock (CK\_INT)

By default, the CK\_INT divided by a 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 APB; otherwise, it doubles the APB clock frequency.

The configuration process is as follows:

- Set the CLKDIV[1:0] bit in the TMRx\_CTRL1 register to set the CK\_INT frequency;
- Set the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register to select count mode. If the one-way count direction is set, configure OWCDIR bit in the TMRx\_CTRL1 register to select the specific direction;
- Set the TMRx\_DIV register to set the counting frequency;
- Set the TMRx\_PR register to set the counting period;
- Set the TMREN bit in the TMRx\_CTRL1 register to enable the counter.

Figure 14-9 Use CK\_INT to drive counter with 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 with filtering and polarity selection), C2IFP2 (STIS=3'b110, channel 2 signal with filtering and polarity selection) and EXT (STIS=3'b111, external input signal with 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 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 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 14-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 14-11 Counting in external clock mode A, with PR=0x32 and DIV=0x0



Figure 14-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 14-13 Counting in external clock mode B, with 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 output by another timer. Set the STIS[2:0] bit to select internal trigger signal to enable counting.

Each timer (TMR2 to TMR5) 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 it takes effect only when the next overflow event occurs.

The internal trigger input is configured as follows:

- Set the TMRx\_PR register to set the counting period;
- Set the TMRx\_DIV register to set the counting frequency;
- Set the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register to set the count mode;
- Set the STIS[2:0] bit (range: 3'b000~3'b011) in the TMRx\_STCTRL register and select internal trigger;
- Set SMSEL[2:0]=3'b111 in the TMRx\_STCTRL register and select external clock mode A;
- Set the TMREN bit in the TMRx\_CTRL1 register to enable TMRx counter.

Table 14-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                | TMR8/USB_SOF <sup>(2)</sup> | TMR3                | TMR4                |
| TMR3             | TMR1                | TMR2                        | TMR5                | TMR4                |
| TMR4             | TMR1                | TMR2                        | TMR3                | TMR8                |
| TMR5             | TMR2                | TMR3                        | TMR4                | TMR8                |

*Note: If there is no corresponding timer in a device, the corresponding trigger signal ISx is not present.*

Figure 14-14 Counter timing with prescaler value changing from 1 to 4



### 14.2.3.2 Counting mode

The timer (TMR2 to TMR5) supports several counting modes to meet different application scenarios. Each timer has an internal 16-bit upcounter, downcounter, upcounter/downcounter. TMR2/5 can be extended to 32-bit by setting the PMEN bit to 1.

The TMRx\_PR register is used to set the counting period. 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. The OVFEN and OVFS bits are used to configure the overflow event.

The TMRx\_DIV register is used to configure the counting frequency. The counter counts once every count clock period (DIV[15:0]+1). Similar to TMRx\_PR register, when the periodic buffer is enabled, the value in the TMRx\_DIV register is updated to the shadow register at an overflow event.

An overflow event is generated by default. Set OVFEN=1 in the TMRx\_CTRL1 to disable generation of update events. The OVFS bit in the TMRx\_CTRL1 register is used to select overflow event source. By default, counter overflow/underflow, setting OVFSWTR bit and the reset signal generated by the slave timer controller in reset mode trigger the generation of an overflow event. When the OVFS bit is set, only counter overflow/underflow triggers an overflow event.

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 14-15 Counter structure



#### Upcounting mode

Set TWCMSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register to enable upcounting mode. In this 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 the OVFIF bit being set to 1. If the overflow event is disabled, the counter is no longer reloaded with the preload value and period value at a counter overflow event; otherwise, the counter is updated with the preload value and period value on an overflow event.

Figure 14-16 Overflow event when PRBEN=0



Figure 14-17 Overflow event when PRBEN=1



### Downcounting mode

TWCMSEL[1:0]=2'b00 and OWCDIR=1'b1 in the TMRx\_CTRL1 register to enable downcounting mode. In this 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 14-18 Counter timing diagram with internal clock divided by 4



### Up/down counting mode

Set TWCMSEL[1:0]≠2'b00 in the TMRx\_CTRL1 register to enable up/down counting mode. In this 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 also used to select the CxIF flag setting method in up/down counting mode. In up/down counting mode 1 (TWCMSEL[1:0]=2'b01), CxIF flag can only be set when the counter counts down; in up/down counting mode 2 (TWCMSEL[1:0]=2'b10), CxIF flag can only be set when the counter counts up; in up/down counting mode 3 (TWCMSEL[1:0]=2'b11), CxIF flag can be set when the counter counts up/down.

*Note: The OWCDIR is read-only in up/down counting mode.*

Figure 14-19 Counter timing diagram with internal clock divided by 1 and TMRx\_PR=0x32



### Encoder interface mode

To enable the encoder interface mode, write SMSEL[2: 0]= 3'b001/3'b010/3'b011. In this mode, the two inputs (C1IN/C2IN) 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.

Figure 14-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 14-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  |
| C1IFP1            | High                                                                | Down          | Up       | No count      | No count |
|                   | Low                                                                 | Up            | Down     | No count      | No count |
| C2IFP2            | High                                                                | No count      | No count | Up            | Down     |
|                   | Low                                                                 | No count      | No count | Down          | Up       |
| C1IFP1 and C2IFP2 | High                                                                | Down          | Up       | Up            | Down     |
|                   | Low                                                                 | Up            | Down     | Down          | Up       |

Figure 14-21 Example of counter behavior in encoder interface mode (encoder mode C)



### 14.2.3.3 TMR input function

Each of TMR2~TMR5 timers has four independent channels, with each channel being configured as input or output.

As input, each channel input signal is handled as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. The C1INSEL bit is used to select the source of C1IRAW from TMRx\_CH1 or the 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 inputs edge detector, and outputs 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 bit. 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 channel 1's C1IFP1 signal that passed through channel 2 edge detection). 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. It can be used for filtering, selection, division and input capture of input signals.

Figure 14-22 Input/output channel 1 main circuit



Figure 14-23 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 or a DMA request will be generated if the CxIEN or CxDEN bit is enabled. If the selected trigger signal is detected when the CxIF is set, a capture overflow event occurs. The TMRx\_CxDT register overwrites the recorded value with the current counter value, and the CxRF is set to 1.

To capture the rising edge of C1IN input, following the configuration procedure mentioned below:

- Set C1C=01 in the TMRx\_CxDT register to select the C1IN as channel 1 input.
- Set the filter bandwidth of C1IN signal (CxDF[3: 0]).
- Set the active edge on the C1IN channel by writing C1P=0 (rising edge) in the TMRx\_CCTR register.
- Program the capture frequency division of C1IN signal (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 (selected by setting the C1INSE in the TMRx\_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.

### Input selection

The TMR2 IS1 (internal trigger input 1) and TMR5 channel 4 are mappable through the TMRx\_RMP register. The TMR2 IS1 can be configured as TMR8\_TRGO, Ethernet PTP output, OTG1\_FS\_SOF or OTG2\_FS\_SOF. TMR5 channel 4 input can be configured as GPIO, LICK, LEXT or ERTC.

### PWM input

The PWM input mode applies to channel 1 and channel 2. To enable this mode, map the C1IN and C2IN to the same TMRx\_CHx, and configure the CxIFPx of channel 1/2 to trigger slave timer controller reset.

The PWM input mode can be used to measure the period and duty cycle of input signal. The period and duty cycle of channel 1 can be measured as follows:

- Set C1C=2'b01 to set C1IN as C1IFP1;
- Set C1P=1'b0 to set C1IFP1 rising edge active;
- Set C2C=2'b10 to set C2IN as C2IFP2;
- Set C2P=1'b1 to set C2IFP2 falling edge active;
- Set STIS=3'b101 to set C1IFP1 as the slave timer trigger signal;
- Set SMSEL=3'b110 to set the slave timer in reset mode;
- Set C1EN=1'b1 and C2EN=1'b1 to enable channel 1 and input capture.

In these configurations, the rising edge of channel 1 input signal triggers capture and saves captured values to the C1DT register, and channel 1 input signal rising edge resets the counter. The falling edge of channel 1 input signal triggers capture and saves captured values to the C2DT register. The period and duty of channel 1 input signal can be calculated through C1DT and C2DT respectively.

Figure 14-24 Example of PWM input mode configuration



Figure 14-25 PWM input mode



#### 14.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 14-26 Capture/compare channel output stage (channel 1 to 4)



##### 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 TMRx\_PR register, while the duty cycle by the TMRx\_CxDT register.

Output compare modes include:

- **PWM mode A:** Set CxOCTRL=3'b110 to enable PWM mode A. In upcounting, when  $TMRx\_C1DT > TMRx\_CVAL$ , C1ORAW outputs high; otherwise, outputs low. In downcounting, when  $TMRx\_C1DT < TMRx\_CVAL$ , C1ORAW outputs low; otherwise, outputs high. To set PWM mode A, the following process is recommended:
  - Set the TMRx\_PR register to set PWM period;
  - Set the TMRx\_CxDT register to set PWM duty cycle;
  - Set CxOCTRL=3'b110 in TMRx\_CM1/CM2 register and set output mode as PWM mode A;
  - Set the TMRx\_DIV register to set the counting frequency;
  - Set the TWCSEL[1:0] bit in the TMRx\_CTRL1 to set the count mode;
  - Set the CxP and CxCP bits in the TMRx\_CCTRL register to set the output polarity;
  - Set the CxEN and CxCEN bits in the TMRx\_CCTRL register to enable channel output;
  - Set the OEN bit in the TMRx\_BRK register to enable TMRx output;
  - Set the corresponding GPIO of TMR output channel as the multiplexed mode;

- Set the TMREN bit in the TMRx\_CTRL1 register to enable TMRx counter.
- **PWM mode B:** Set CxOCTRL=3'b111 to enable PWM mode B. In upcounting, when TMRx\_C1DT>TMRx\_CVAL, C1ORAW outputs low; otherwise, outputs high. In downcounting, when TMRx\_C1DT<TMRx\_CVAL, C1ORAW outputs high; otherwise, outputs low.
- **Forced output mode:** Set CxOCTRL=3'b100/101 to enable forced output mode. In this case, the CxORAW is forced to be the programmed level, irrespective of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.
- **Output compare mode:** Set CxOCTRL=3'b001/010/011 to enable output compare mode. 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).
- **One-pulse mode:** This is a particular case of PWM mode. Set OCMEN=1 to enable one-pulse mode. 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 as in upcounting mode, the configuration must follow the rule: CVAL<CxDT≤PR; in downcounting mode, CVAL>CxDT is required.
- **Fast output mode:** Set CxOIEN=1 to enable this mode. If enabled, the CxORAW signal will not change when the counter value matches the CxDT, but 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 27](#) gives an example of output compare mode (toggle) with C1DT=0x3. When the counter value is equal to 0x3, C1OUT toggles.

[Figure 28](#) gives an example of the combination between upcounting mode and PWM mode A. The output signal behaves when PR=0x32 but CxDT is configured with a different value.

[Figure 29](#) gives an example of the combination between up/down counting mode and PWM mode A. The output signal behaves when PR=0x32 but CxDT is configured with a different value.

[Figure 30](#) gives an example of the combination between upcounting mode and one-pulse PWM mode B. The counter only counts only one cycle, and the output signal sends only one pulse.

Figure 14-27 C1ORAW toggles when counter value matches the C1DT value



Figure 14-28 Upcounting mode and PWM mode A



Figure 14-29 Up/down counting mode and PWM mode A



Figure 14-30 One-pulse mode



### Master timer event output

When TMR is selected as the master timer, the following signal sources can be selected as TRGOUT signal to output to the slave timer, by setting the PTOS bit in the TMRxCTRL2 register.

- PTOS=3'b000, TRGOUT outputs software overflow event (OVFSWTR bit in the TMRx\_SWEVT register);
- PTOS=3'b001, TRGOUT outputs counter enable signal;
- PTOS=3'b010, TRGOUT outputs counter overflow event;
- PTOS=3'b011, TRGOUT outputs capture and compare event;
- PTOS=3'b100, TRGOUT outputs C1ORAW signal;
- PTOS=3'b101, TRGOUT outputs C2ORAW signal;
- PTOS=3'b110, TRGOUT outputs C3ORAW signal;
- PTOS=3'b111, TRGOUT outputs C4ORAW signal.

### 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 14-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 14-31 Clearing CxORAW (PWM mode A) by EXT input



### 14.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 mode 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 14-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 14-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 14-34 Example of trigger mode



### Master/slave timer interconnection

Both Master and slave timer can be configured in different master and slave modes respectively. The combination of both them can be used for various purposes. The figure below provides an example of interconnection between master timer and slave timer.

Figure 14-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 registers).
- 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 14-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/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 14-37 Starting master and slave timers synchronously by an external trigger



#### 14.2.3.6 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. Refer to Chapter 30.2 for more information.

#### 14.2.4 TMRx registers

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

All TMR2 and TMR5 registers are mapped into a 16-bit addressable space.

Table 14-5 TMR2 and TMR 5 register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| TMRx_CTRL1  | 0x00   | 0x0000      |
| TMRx_CTRL2  | 0x04   | 0x0000      |
| TMRx_STCTRL | 0x08   | 0x0000      |
| TMRx_IDEN   | 0x0C   | 0x0000      |
| TMRxISTS    | 0x10   | 0x0000      |
| TMRxSWEVT   | 0x14   | 0x0000      |
| TMRx_CM1    | 0x18   | 0x0000      |
| TMRx_CM2    | 0x1C   | 0x0000      |
| TMRx_CCTRL  | 0x20   | 0x0000      |
| TMRx_CVAL   | 0x24   | 0x0000      |
| TMRx_DIV    | 0x28   | 0x0000      |

|              |      |        |
|--------------|------|--------|
| TMRx_PR      | 0x2C | 0x0000 |
| TMRx_C1DT    | 0x34 | 0x0000 |
| TMRx_C2DT    | 0x38 | 0x0000 |
| TMRx_C3DT    | 0x3C | 0x0000 |
| TMRx_C4DT    | 0x40 | 0x0000 |
| TMRx_DMACTRL | 0x48 | 0x0000 |
| TMRx_DMADT   | 0x4C | 0x0000 |
| TMR2_RMP     | 0x50 | 0x0000 |
| TMR5_RMP     | 0x50 | 0x0000 |

#### 14.2.4.1 TMR2 to TMR5 control register 1 (TMRx\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 11 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 10     | PMEN     | 0x0         | rw   | <p>Plus Mode Enable<br/>This bit is used to enable TMRx plus mode. In this mode, TMRx_CVAL, TMRx_PR and TMRx_CxDT are extended from 16-bit to 32-bit.<br/>0: Disabled<br/>1: Enabled</p> <p><i>Note: This function is only valid for TMR2 and TMR5. It is not applicable to other TMRs.</i></p> <p><i>In plus mode or when disabled, only 16-bit value can be written to TMRx_CVAL, TMRx_PR and TMRx_CxDT registers.</i></p>                                                        |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | <p>Clock division<br/>This field is used to set the division ratio between digital filter sampling frequency (<math>f_{DTS}</math>) and timer clock frequency (<math>f_{CK\_INT}</math>).<br/>00: No division, <math>f_{DTS}=f_{CK\_INT}</math><br/>01: Divided by 2, <math>f_{DTS}=f_{CK\_INT}/2</math><br/>10: Divided by 4, <math>f_{DTS}=f_{CK\_INT}/4</math><br/>11: Reserved</p>                                                                                              |
| 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: Two-way counting mode1, count up and down alternately, the output flag bit is set only when the counter counts down<br/>10: Two-way counting mode2, count up and down alternately, the output flag bit is set only when the counter counts up<br/>11: Two-way counting mode3, count up and down alternately, the output flag bit is set when the counter counts up / 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 overflow event<br/>0: The counter does not stop at an overflow event<br/>1: The counter stops at an overflow event</p>                                                                                                                                                                                                                                                                       |
| Bit 2      | OVFS     | 0x0         | rw   | <p>Overflow event source<br/>This bit is used to select overflow event or DMA request sources.</p>                                                                                                                                                                                                                                                                                                                                                                                  |

|       |       |     |    |                                                                                                                                                            |
|-------|-------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | 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: Disabled<br>1: Enabled                                                                                                                    |

#### 14.2.4.2 TMR2 to TMR5 control register 2 (TMRx\_CTRL2)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 8 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                     |
| 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<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.                                                                                                                                                                                                                                     |

#### 14.2.4.3 TMR2 to TMR5 slave timer control register (TMRx\_STCTRL)

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|--------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 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 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 |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|----------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 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.<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 14-3 and 14-5 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. |

#### 14.2.4.4 TMR2 to TMR5 DMA/interrupt enable register (TMRx\_IDEN)

| Bit    | Name     | Reset value | Type | Description                                                    |
|--------|----------|-------------|------|----------------------------------------------------------------|
| Bit 15 | Reserved | 0x0         | resd | Kept at its default value                                      |
| Bit 14 | TDEN     | 0x0         | rw   | Trigger DMA request enable<br>0: Disabled<br>1: Enabled        |
| Bit 13 | Reserved | 0x0         | resd | Kept at its 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 its default value                                      |
| Bit 6  | TIEN     | 0x0         | rw   | Trigger interrupt enable                                       |

|       |          |     |      |                                                         |
|-------|----------|-----|------|---------------------------------------------------------|
|       |          |     |      | 0: Disabled<br>1: Enabled                               |
| Bit 5 | Reserved | 0x0 | resd | Kept at its 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  |

#### 14.2.4.5 TMR2 to TMR5 interrupt status register (TMRx\_ISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 13 | Reserved | 0x0         | resd | Kept at its 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 its 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”.<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      | Reserved | 0x0         | resd | Kept at its 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 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.                                                                                                                                                                                                                                                                                                                                              |

0: No overflow event occurs  
 1: Overflow event is generated. If OVFEN=0 and OVFS=0 in the TMRx\_CTRL1 register:  
 - An overflow event is generated when OVFG= 1 in the TMRx\_SWEVE register;  
 - An overflow event is generated when the counter CVAL is reinitialized by a trigger event.

#### 14.2.4.6 TMR2 to TMR5 software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                           |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 7 | Reserved | 0x000       | resd | Kept at its 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 its default value.                                                                                                                            |
| Bit 4     | C4SWTR   | 0x0         | wo   | Channel 4 event triggered by software<br>Please refer to C1M description.                                                                             |
| Bit 3     | C3SWTR   | 0x0         | wo   | Channel 3 event triggered by software<br>Please refer to C1M description.                                                                             |
| Bit 2     | C2SWTR   | 0x0         | wo   | Channel 2 event triggered by software<br>Please refer to C1M 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.  |

#### 14.2.4.7 TMR2 to TMR5 channel mode register 1 (TMRx\_CM1)

##### Output compare mode:

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                  |
|------------|---------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                                                                                                                                                                                                          |
| 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 register. |
| Bit 7      | C1OSEN  | 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 6: 4   | C1OCTRL | 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.          |

|          |        |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|--------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |     |    | 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 3    | C1OBEN | 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 2    | C1OIEN | 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.<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: 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.                                                                                                                                                    |

**Input capture mode:**

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                            |
|------------|--------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 |

|          |        |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|--------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |     |    | 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.                                                |

#### 14.2.4.8 TMR2 to TMR5 channel mode register 2 (TMRx\_CM2)

##### Output compare mode:

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                         |
|------------|---------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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<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   | 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 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<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   |                                                                                                                                                                                                                                                                                                                                                                     |

##### Input capture mode:

| Bit        | Name   | Reset value | Type | Description              |
|------------|--------|-------------|------|--------------------------|
| Bit 15: 12 | C4DF   | 0x0         | rw   | Channel 4 digital filter |
| Bit 11: 10 | C4IDIV | 0x0         | rw   | Channel 4 input divider  |

|          |        |     |    |                                                                                                                                                                                                                                                                                                                                                                     |
|----------|--------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 9: 8 | C4C    | 0x0 | rw | 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 7: 4 | C3DF   | 0x0 | rw | Channel 3 digital filter                                                                                                                                                                                                                                                                                                                                            |
| Bit 3: 2 | C3IDIV | 0x0 | rw | Channel 3 input divider                                                                                                                                                                                                                                                                                                                                             |
| Bit 1:0  | C3C    | 0x0 | rw | 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. |

#### 14.2.4.9 TMR2 to TMR5 channel control register (TMRx\_CCTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 14 | Reserved | 0x0         | resd | Kept at its 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: 10 | Reserved | 0x0         | resd | 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: 6   | Reserved | 0x0         | resd | Kept at its 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: 2   | Reserved | 0x0         | resd | Kept at its 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>0: C1IN active edge is on its rising edge. When used as external trigger, C1IN is not inverted.<br>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 14-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.

#### 14.2.4.10 TMR2 to TMR5 counter value (TMRx\_CVAL)

| Bit        | Name | Reset value | Type | Description                                                                                                                     |
|------------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | CVAL | 0x0000      | rw   | Counter value<br>When TMR2 or TMR5 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the CVAL is expanded to 32 bits. |
| Bit 15: 0  | CVAL | 0x0000      | rw   | Counter value                                                                                                                   |

#### 14.2.4.11 TMR2 to TMR5 division value (TMRx\_DIV)

| Bit       | Name | Reset value | Type | Description                                                                                                                                           |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | DIV  | 0x0000      | rw   | Divider value<br>The counter clock frequency $f_{CK\_CNT} = f_{TMR\_CLK} / (DIV[15:0] + 1)$ .<br>DIV contains the value written at an overflow event. |

#### 14.2.4.12 TMR2 to TMR5 period register (TMRx\_PR)

| Bit        | Name | Reset value | Type | Description                                                                                                                  |
|------------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | PR   | 0x0000      | rw   | Period value<br>When TMR2 or TMR5 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the PR is expanded to 32 bits. |
| Bit 15: 0  | PR   | 0x0000      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0.       |

#### 14.2.4.13 TMR2 to TMR5 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 or TMR5 enables plus mode (the PMEN bit in the TMR_CTRL1 register), the C1DT is expanded 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. |

#### 14.2.4.14 TMR2 to TMR5 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 or TMR5 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. |

#### 14.2.4.15 TMR2 to TMR5 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 or TMR5 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<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).<br>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. |

#### 14.2.4.16 TMR2 to TMR5 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 or TMR5 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. |

#### 14.2.4.17 TMR2 to TMR5 DMA control register (TMRx\_DMACTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                       |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 13 | Reserved | 0x0         | resd | Kept at its 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 its 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>.....        |

#### 14.2.4.18 TMR2 to TMR5 DMA data register (TMRx\_DMADT)

| Bit       | Name  | Reset value | Type | Description                                                                                                                                                                                                |
|-----------|-------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

#### 14.2.4.19 TMR5 channel input remapping register (TMR2\_RMP)

| Bit        | Name          | Reset value | Type | Description                                                                                                   |
|------------|---------------|-------------|------|---------------------------------------------------------------------------------------------------------------|
| Bit 15: 12 | Reserved      | 0x0         | resd | Kept at its default value.                                                                                    |
| Bit 11: 10 | TMR2_IS1_IRMP | 0x0         | rw   | TMR2 IS1 input remap<br>00: TMR8_TRGO output<br>01: Ethernet PTP output<br>10: OTG1_FS_SOF<br>11: OTG2_FS_SOF |
| Bit 9:0    | Reserved      | 0x000       | resd | Kept at its default value.                                                                                    |

#### 14.2.4.20 TMR2 channel input remapping register (TMR5\_RMP)

| Bit       | Name          | Reset value | Type | Description                                                                                                                                                 |
|-----------|---------------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 8 | Reserved      | 0x00        | resd | Kept at its default value.                                                                                                                                  |
| Bit 7: 6  | TMR5_CH4_IRMP | 0x0         | rw   | TMR5 channel 4 input remap<br>00: TMR5 channel 4 input connected to GPIO<br>01: Internal clock LICK<br>10: Internal clock LEXT<br>11: ERTC wakeup interrupt |
| Bit 5: 0  | Reserved      | 0x00        | resd | Kept at its default value.                                                                                                                                  |

### 14.3 General-purpose timer (TMR9 to TMR14)

#### 14.3.1 TMR9 to TMR14 introduction

The general-purpose timer (TMR9 to TMR14) consists of a 16-bit counter supporting upcounting mode. These timers can be synchronized.

#### 14.3.2 TMR9 to TMR14 main features

##### 14.3.2.1 TMR9 and TMR12 main features

The main functions of general-purpose TMR9 and TMR12 include:

- Source of counter clock: internal clock and external clock
- 16-bit upcounter
- 2 independent channels for input capture, output compare, PWM generation and one-pulse mode output
- Synchronization control between master and slave timers
- Interrupt is generated at overflow event, trigger event and channel event

Figure 14-38 Block diagram of general-purpose TMR9/12



### 14.3.2.2 TMR10, TMR11, TMR13 and TMR14 main features

The main functions of general-purpose TMRx (TMR10, TMR11, TMR13 and TMR14) include:

- Source of counter clock: internal clock
- 16-bit upcounter
- 1 independent channel for input capture, output compare, PWM generation
- Synchronization control between master and slave timers
- Interrupt is generated at overflow event and channel event

Figure 14-39 Block diagram of general-purpose TMR10/11/13/14



### 14.3.3 TMR9 to TMR14 functional overview

#### 14.3.3.1 Counting clock

The count clock of general-purpose timers can be provided by the internal clock (CK\_INT), external clock (external clock mode A) and internal trigger input (ISx).

Figure 14-40 Count clock



#### Internal clock (CK\_INT)

By default, the CK\_INT 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 APB; otherwise, it doubles the APB clock frequency.

The configuration process is as follows:

- Set the CLKDIV[1:0] bit in the TMRx\_CTRL1 register to set the CK\_INT frequency;
- Set the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register to select count mode. If the one-way count direction is set, configure OWCDIR bit in the TMRx\_CTRL1 register to select the specific direction;
- Set the TMRx\_DIV register to set the counting frequency;
- Set the TMRx\_PR register to set the counting period;
- Set the TMREN it in the TMRx\_CTRL1 register to enable the counter.

Figure 14-41 Use CK\_INT to drive counter, with TMRx\_DIV=0x0 and TMRx\_PR=0x16

**External clock (TMR9/12 only)**

The counter clock can be provided by TRGIN signal.

**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 with filtering and polarity selection) and C2IFP2 (STIS=3'b110, 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\_CCTR 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 14-42 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 14-43 Counting in external clock mode A, with 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 output by another timer. Set the STIS[2:0] bit to select internal trigger signal to enable counting.

Each timer (TMR9 ~TMR14) 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 it takes effect only when the next overflow event occurs.

The internal trigger input is configured as follows:

- Set the TMRx\_PR register to set the counting period;
- Set the TMRx\_DIV register to set the counting frequency;
- Set the STIS[2:0] bit (range: 3'b000~3'b011) in the TMRx\_STCTRL register and select internal trigger;
- Set SMSEL[2:0]=3'b111 in the TMRx\_STCTRL register and select external clock mode A;
- Set the TMREN bit in the TMRx\_CTRL1 register to enable TMRx counter.

Figure 14-44 Counter timing with prescaler value changing from 1 to 4



Table 14-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_TRGOUT       | TMR3_TRGOUT         | TMR10_OC            | TMR11_OC            |
| TMR12            | TMR4_TRGOUT       | TMR5_TRGOUT         | TMR13_OC            | TMR14_OC            |

*Note: If there is no corresponding timer in a device, the corresponding trigger signal ISx is not present.*

### 14.3.3.2 Counting mode

The general-purpose timer only supports upcounting mode, and it consists of a 16-bit counter.

The TMRx\_PR register issued to set the counting period. 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. The OVFEN and OVFS bits are used to configure the overflow event.

The TMRx\_DIV register is used to configure the counting frequency. The counter counts once every count clock period (DIV[15:0]+1). Similar to the TMRx\_PR register, when the periodic buffer is enabled, the value in the TMRx\_DIV register is updated to the shadow register at an overflow event.

Reading the TMRx\_CNT register returns to the current counter value, and writing to the TMRx\_CNT register updates the current counter value to the value being written.

An overflow event is generated by default. Set OVFEN=1 in the TMRx\_CTRL1 to disable generation of update events. The OVFS bit in the TMRx\_CTRL1 register is used to select overflow event source. By default, counter overflow/underflow, setting OVFSWTR bit and the reset signal generated by the slave timer controller in reset mode trigger the generation of an overflow event. When the OVFS bit is set, only counter overflow/underflow triggers an overflow event.

Setting TMREN=1 to enable 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 14-45 Counter structure



#### Upcounting mode

Set TWCSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register to enable upcounting mode. In this 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 the OVFIF bit being set to 1. If the overflow event is disabled, the counter is no longer reloaded with the preload value and period value at a counter overflow event; otherwise, the counter is updated with the preload value and period value on an overflow event.

Figure 14-46 Overflow event when PRBEN=0



Figure 14-47 Overflow event when PRBEN=1



### 14.3.3.3 TMR input function

Each timer of TMR9 and TMR12 has two independent channels, while each of TMR10, TMR11, TMR13 and TMR14 has an independent channel. Each channel can be configured as input or output.

As input, each channel input signal is handled as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. Set the C1INSEL bit to select TMRx\_CH1 as the source of C1IRAW.
- CxIRAW inputs digital filter and outputs filtered CxIF signal. The digital filter uses the CxDI bit to program sampling frequency and sampling times.
- CxIF inputs edge detector, and outputs 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 bit. 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 channel 1's C1IFP1 signal that passed through channel 2 edge detection). 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. It can be used for filtering, selection, division and input capture of input signals.

Figure 14-48 Input/output channel 1 main circuit



Figure 14-49 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. An interrupt or a DMA request will be generated if the CxIEN or CxDEN bit is enabled. If the selected trigger signal is detected when the CxIF is set to 1, a capture overflow event occurs. The TMRx\_CxDT register overwrites the recorded value with the current counter value, and the CxRF is set to 1.

To capture the rising edge of C1IN input, following the configuration procedure mentioned below:

- Set C1C=01 in the TMRx\_CxDT register to select the C1IN as channel 1 input;
- Set the filter bandwidth of C1IN signal (CxDF[3: 0]);
- Set the active edge on the C1IN channel by writing C1P=0 (rising edge) in the TMRx\_CCTR Register;
- Program the capture frequency division of C1IN signal (C1DIV[1: 0]);
- Enable channel 1 input capture (C1EN=1);
- If needed, enable the relevant interrupt by setting the C1IEN bit in the TMRx\_IDEN register.

## PWM input (TMR9/12)

The PWM input mode applies to channel 1 and channel 2. To enable this mode, map the C1IN and C2IN to the same TMRx\_CHx, and configure the CxIFPx of channel 1/2 to trigger slave timer controller reset.

The PWM input mode can be used to measure the period and duty cycle of input signal. The period and duty cycle of channel 1 can be measured as follows:

- Set C1C=2'b01 to set C1IN as C1IFP1;
- Set C1P=1'b0 to set C1IFP1 rising edge active;
- Set C2C=2'b10 to set C2IN as C1IFP2;
- Set C2P=1'b1 to set C1IFP2 falling edge active;
- Set STIS=3'b101 to set C1IFP1 as the slave timer trigger signal;
- Set SMSEL=3'b110 to set the slave timer in reset mode;
- Set C1EN=1'b1 and C2EN=1'b1 to enable channel 1 and input capture.

In these configurations, the rising edge of channel 1 input signal triggers capture and saves captured values to the C1DT register, and channel 1 input signal rising edge resets the counter. The falling edge of channel 1 input signal triggers capture and saves captured values to the C2DT register. The period and duty of channel 1 input signal can be calculated through C1DT and C2DT respectively.

Figure 14-50 Example of PWM input mode configuration



Figure 14-51 PWM input mode



#### 14.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 14-52 Capture/compare channel output stage (channel 1)



##### 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  $TMRx\_PR$  register, while the duty cycle by the  $TMRx\_CxDT$  register.

Output compare modes include:

- **PWM mode A:** Set  $CxOCTRL=3'b110$  to enable PWM mode A. In upcounting, when  $TMRx\_C1DT > TMRx\_CVAL$ ,  $C1ORAW$  outputs high; otherwise, outputs low. In downcounting, when  $TMRx\_C1DT < TMRx\_CVAL$ ,  $C1ORAW$  outputs low; otherwise, outputs high. To set PWM mode A, the following process is recommended:
  - Set the  $TMRx\_PR$  register to set PWM period;
  - Set the  $TMRx\_CxDT$  register to set PWM duty cycle;
  - Set  $CxOCTRL=3'b110$  in  $TMRx\_CM1/CM2$  register and set output mode as PWM mode A;
  - Set the  $TMRx\_DIV$  register to set the counting frequency;
  - Set the  $TWCMSEL[1:0]$  bit in the  $TMRx\_CTRL1$  to set the count mode;
  - Set the  $CxP$  and  $CxCP$  bits in the  $TMRx\_CCTRL$  register to set the output polarity;
  - Set the  $CxEN$  and  $CxCEN$  bits in the  $TMRx\_CCTRL$  register to enable channel output;
  - Set the  $OEN$  bit in the  $TMRx\_BRK$  register to enable TMRx output;
  - Set the corresponding GPIO of TMR output channel as the multiplexed mode;
  - Set the  $TMREN$  bit in the  $TMRx\_CTRL1$  register to enable TMRx counter.

- PWM mode B:** Set CxOCTRL=3'b111 to enable PWM mode B. In upcounting, when TMRx\_C1DT>TMRx\_CVAL, C1ORAW outputs low; otherwise, outputs high. In downcounting, when TMRx\_C1DT<TMRx\_CVAL, C1ORAW outputs high; otherwise, outputs low.
- Forced output mode:** Set CxOCTRL=3'b100/101 to enable forced output mode. In this case, the CxORAW is forced to be the programmed level, irrespective of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.
- Output compare mode:** Set CxOCTRL=2'b001/010/011 to enable output compare mode. 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).
- One-pulse mode (TMR9/12 only):** This is a particular case of PWM mode. Set OCMEN=1 to enable one-pulse mode. 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 as in upcounting mode, the configuration must follow the rule: CVAL<CxDT≤PR; in downcounting mode, CVAL>CxDT is required.
- Fast output mode (TMR9/12 only):** Set CxOIEN=1 to enable this mode. If enabled, the CxORAW signal will not change when the counter value matches the CxDT, but 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 53 gives an example of output compare mode (toggle) with C1DT=0x3. When the counter value is equal to 0x3, C1OUT toggles.

Figure 54 gives an example of the combination between upcounting mode and PWM mode A. The output signal behaves when PR=0x32 but CxDT is configured with a different value.

Figure 55 gives an example of the combination between upcounting mode and one-pulse PWM mode B. The counter only counts only one cycle, and the output signal sends only one pulse.

Figure 14-53 C1ORAW toggles when counter value matches the C1DT value



Figure 14-54 Upcounting mode and PWM mode A



Figure 14-55 One-pulse mode



### 14.3.3.5 TMR synchronization

TMR9 and TMR12 are linked together internally for timer synchronization. Slave timer is selected by setting the SMSEL[2: 0] bit.

#### 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 14-56 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 14-57 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 14-58 Example of trigger mode

**14.3.3.6 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. Refer to Chapter 30.2 for more information.

**14.3.4 TMR9 and TMR12 registers**

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

All TMR9 and TMR12 registers are mapped into a 16-bit addressable space.

Table 14-8 TMR9 and TMR12 register map and reset value

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| TMRx_CTRL1  | 0x00   | 0x0000      |
| TMRx_STCTRL | 0x08   | 0x0000      |
| TMRx_IDEN   | 0x0C   | 0x0000      |
| TMRxISTS    | 0x10   | 0x0000      |
| TMRxSWEVT   | 0x14   | 0x0000      |
| TMRx_CM1    | 0x18   | 0x0000      |
| TMRx_CCTRL  | 0x20   | 0x0000      |
| TMRxCVAL    | 0x24   | 0x0000      |
| TMRxDIV     | 0x28   | 0x0000      |
| TMRx_PR     | 0x2C   | 0x0000      |
| TMRxC1DT    | 0x34   | 0x0000 0000 |
| TMRxC2DT    | 0x38   | 0x0000 0000 |

**14.3.4.1 TMR9 and TMR12 control register 1 (TMRx\_CTRL1)**

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x00        | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                                                |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | <p>Clock divider<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>).<br/>00: No division, <math>f_{DTS}=f_{CK\_INT}</math><br/>01: Divided by 2, <math>f_{DTS}=f_{CK\_INT}/2</math><br/>10: Divided by 4, <math>f_{DTS}=f_{CK\_INT}/4</math><br/>11: Reserved</p> |
| Bit 7      | PRBEN    | 0x0         | rw   | Period buffer enable                                                                                                                                                                                                                                                                                                                                                                     |

|          |          |     |      |                                                                                                                                                                                                                                 |
|----------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 0: Period buffer is disabled<br>1: Period buffer is enabled                                                                                                                                                                     |
| Bit 6: 4 | Reserved | 0x0 | resd | Kept at its default value                                                                                                                                                                                                       |
|          |          |     |      | One cycle mode enable                                                                                                                                                                                                           |
| Bit 3    | OCMEN    | 0x0 | rw   | This bit is use 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                                                             |
|          |          |     |      | Overflow event source                                                                                                                                                                                                           |
| Bit 2    | OVFS     | 0x0 | rw   | 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 |
|          |          |     |      | Overflow event enable                                                                                                                                                                                                           |
| Bit 1    | OVFEN    | 0x0 | rw   | 0: Enabled<br>1: Disabled                                                                                                                                                                                                       |
|          |          |     |      | TMR enable                                                                                                                                                                                                                      |
| Bit 0    | TMREN    | 0x0 | rw   | 0: Enabled<br>1: Disabled                                                                                                                                                                                                       |

#### 14.3.4.2 TMR9 and TMR12 slave timer control register (TMRx\_STCTRL)

| Bit      | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:7 | Reserved | 0x000       | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          |          |             |      | 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: Reserved<br>Please refer to Table 14-7 for more information on ISx for each timer. |
| Bit 6: 4 | STIS     | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 3    | Reserved | 0x0         | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          |          |             |      | Subordinate TMR mode selection<br>000: Slave mode is disabled<br>001: Reserved<br>010: Reserved<br>011: Reserved                                                                                                                                                                                                                                                                                                                          |
| Bit 2: 0 | SMSEL    | 0x0         | rw   | 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                                                                                                          |

#### 14.3.4.3 TMR9 and TMR12 DMA/interrupt enable register (TMRx\_IDEN)

| Bit      | Name     | Reset value | Type | Description                |
|----------|----------|-------------|------|----------------------------|
| Bit 15:7 | Reserved | 0x0         | resd | Kept at its default value. |
|          |          |             |      | Trigger interrupt enable   |
| Bit 6    | TIEN     | 0x0         | rw   | 0: Disabled<br>1: Enabled  |
| Bit 5:3  | Reserved | 0x0         | resd | Kept at its default value. |
|          |          |             |      | Channel 2 interrupt enable |
| Bit 2    | C2IEN    | 0x0         | rw   | 0: Disabled<br>1: Enabled  |

|       |        |     |    |                                                         |
|-------|--------|-----|----|---------------------------------------------------------|
| Bit 1 | C1IEN  | 0x0 | rw | Channel 1 interrupt enable<br>0: Disabled<br>1: Enabled |
| Bit 0 | OVFLEN | 0x0 | rw | Overflow interrupt enable<br>0: Disabled<br>1: Enabled  |

#### 14.3.4.4 TMR9 and TMR12 interrupt status register (TMRx\_ISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 11 | Reserved | 0x0         | resd | Kept at its 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: 7   | Reserved | 0x0         | resd | Kept at its 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".<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: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.                                                                                                                                                                                                                                                                            |

#### 14.3.4.5 TMR9 and TMR12 software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                           |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 7 | Reserved | 0x000       | resd | Kept at its 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:3   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                            |
| Bit 2     | C2SWTR   | 0x0         | wo   | Channel 2 event triggered by software<br>Please refer to C1M 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.
 

---

#### 14.3.4.6 TMR9 and TMR12 channel mode register1 (TMRx\_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 15     | Reserved | 0x0         | resd | Kept at its 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 its 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 |
| Bit 6: 4   | C1OCTRL  | 0x0         | rw   | - 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.                                                                                             |
|            |          |             |      | <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>                                                                                                                                                                                  |
|            |          |             |      | 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.                                                                                                                                                                                                                                        |
| Bit 3      | C1OBEN   | 0x0         | rw   | 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 2      | C1OIEN   | 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.                                                                                                                                                                                                                                        |

|            |        |             |      | 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 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}/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 |
|            |        |             |      | 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'                                                                                                                                                                                                                                                                                                                                           |
|            |        |             |      | 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

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.

#### 14.3.4.7 TMR9 and TMR12 channel control register (TMRx\_CCTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 6 | Reserved | 0x0         | resd | Kept at its 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: 2  | Reserved | 0x0         | resd | Kept at its 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>0: C1IN active edge is on its rising edge. When used as external trigger, C1IN is not inverted.<br>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 14-9 Standard CxOUT channel output control bit

| CxEN bit | CxOUT output state        |
|----------|---------------------------|
| 0        | Output disabled (CxOUT=0) |
| 1        | CxOUT = CxORAW + polarity |

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.

#### 14.3.4.8 TMR9 and TMR12 counter value (TMRx\_CVAL)

| Bit       | Name | Reset value | Type | Description   |
|-----------|------|-------------|------|---------------|
| Bit 15: 0 | CVAL | 0x0000      | rw   | Counter value |

#### 14.3.4.9 TMR9 and TMR12 division value (TMRx\_DIV)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

#### 14.3.4.10 TMR9 and TMR12 period register (TMRx\_PR)

| Bit       | Name | Reset value | Type | Description                                                                                                            |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | PR   | 0x0000      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

#### 14.3.4.11 TMR9 and TMR12 channel 1 data register (TMRx\_C1DT)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its 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: |

C1DT is the value to be compared with the CVAL value. Whether the written value takes effect immediately depends on the C1OBEN bit, and the corresponding output is generated on C1OUT as configured.

#### 14.3.4.12 TMR9 and TMR12 channel 2 data register (TMRx\_C2DT)

| Bit        | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | C2DT | 0x0000      | resd | Kept at its 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. |

#### 14.3.5 TMR10, TMR11, TMR13 and TMR14 registers

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

All TMR10, TMR11, TMR13 and TMR14 registers are mapped into a 1-bit addressable space.

Table 14-10 TMR10, TMR11, TMR13 and TMR14 register map and reset value

| Register   | Offset | Reset value |
|------------|--------|-------------|
| TMRx_CTRL1 | 0x00   | 0x0000      |
| TMRx_IDEN  | 0x0C   | 0x0000      |
| TMRxISTS   | 0x10   | 0x0000      |
| TMRxSWEVT  | 0x14   | 0x0000      |
| TMRx_CM1   | 0x18   | 0x0000      |
| TMRxCCTRL  | 0x20   | 0x0000      |
| TMRxCVAL   | 0x24   | 0x0000      |
| TMRxDIV    | 0x28   | 0x0000      |
| TMRxPR     | 0x2C   | 0x0000      |
| TMRxC1DT   | 0x34   | 0x0000      |

#### 14.3.5.1 TMR10, TMR11, TMR13 and TMR14 control register 1 (TMRx\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                               |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x00        | resd | Kept at its 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}$ ).<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: 4   | Reserved | 0x0         | resd | Default value                                                                                                                                                                                                                                                                                                             |
| 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                                                                                                                                                                    |

|       |       |     |    |                                                                                                                                                            |
|-------|-------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | 1: The counter stops at an overflow event                                                                                                                  |
|       |       |     |    | Overflow event source                                                                                                                                      |
|       |       |     |    | This bit is used to select overflow event or DMA request sources.                                                                                          |
| Bit 2 | OVFS  | 0x0 | rw | 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                                                                                                                    |

#### 14.3.5.2 TMR10, TMR11, TMR13 and TMR14 DMA/interrupt enable register (TMRx\_IDEN)

| Bit      | Name     | Reset value | Type | Description                                             |
|----------|----------|-------------|------|---------------------------------------------------------|
| Bit 15:2 | Reserved | 0x0         | resd | Kept at its 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  |

#### 14.3.5.3 TMR10, TMR11, TMR13 and TMR14 interrupt status register (TMRxISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x0         | resd | Kept at its 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: 2   | Reserved | 0x0         | resd | Kept at its 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 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.                                                                                                                                                                                                                                                                            |

#### 14.3.5.4 TMR10, TMR11, TMR13 and TMR14 software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                           |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 2 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                            |
| 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. |
|-------|---------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------|

### 14.3.5.5 TMR10, TMR11, TMR13 and TMR14 channel mode register 1 (TMRx\_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 15:7 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 6: 4 | C1OCTRL  | 0x0         | rw   | <p>Channel 1 output control<br/>This field defines the behavior of the original signal C1ORAW.</p> <ul style="list-style-type: none"> <li>000: Disconnected. C1ORAW is disconnected from C1OUT;</li> <li>001: C1ORAW is high when TMRx_CVAL=TMRx_C1DT</li> <li>010: C1ORAW is low when TMRx_CVAL=TMRx_C1DT</li> <li>011: Switch C1ORAW level when TMRx_CVAL=TMRx_C1DT</li> <li>100: C1ORAW is forced low</li> <li>101: C1ORAW is forced high.</li> <li>110: PWM mode A <ul style="list-style-type: none"> <li>- OWCDIR=0, C1ORAW is high once TMRx_C1DT&gt;TMRx_CVAL, else low;</li> <li>- OWCDIR=1, C1ORAW is low once TMRx_C1DT &lt;TMRx_CVAL, else high;</li> </ul> </li> <li>111: PWM mode B <ul style="list-style-type: none"> <li>- OWCDIR=0, C1ORAW is low once TMRx_C1DT &gt;TMRx_CVAL, else high;</li> <li>- OWCDIR=1, C1ORAW is high once TMRx_C1DT &lt;TMRx_CVAL, else low.</li> </ul> </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<br/>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<br/>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<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':</p> <ul style="list-style-type: none"> <li>00: Output</li> <li>01: Input, C1IN is mapped on C1IFP1</li> <li>10: Reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

11: Reserved

**Input capture mode:**

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 8 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           |          |             |      | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|           |          |             |      | 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 7: 4  | C1DF     | 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 3: 2  | C1IDIV   | 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 1: 0  | C1C      | 0x0         | rw   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**14.3.5.6 TMR10, TMR11, TMR13 and TMR14 channel control register (TMRx\_CCTRL)**

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 2 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                         |
|           |          |             |      | 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                                                                                                                        |
| Bit 1     | C1P      | 0x0         | rw   | 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.<br>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 14-11 Standard CxOUT channel output control bit

| CxEN bit | CxOUT output state        |
|----------|---------------------------|
| 0        | Output disabled (CxOUT=0) |
| 1        | CxOUT = CxORAW + polarity |

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.

#### 14.3.5.7 TMR10, TMR11, TMR13 and TMR14 counter value (TMRx\_CVAL)

| Bit       | Name | Reset value | Type | Description   |
|-----------|------|-------------|------|---------------|
| Bit 15: 0 | CVAL | 0x0000      | rw   | Counter value |

#### 14.3.5.8 TMR10, TMR11, TMR13 and TMR14 division value (TMRx\_DIV)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                  |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

#### 14.3.5.9 TMR10, TMR11, TMR13 and TMR14 period register (TMRx\_PR)

| Bit       | Name | Reset value | Type | Description                                                                                                            |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | PR   | 0x0000      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

#### 14.3.5.10 TMR10, TMR11, TMR13 and TMR14 channel 1 data register (TMRx\_C1DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

## 14.4 Advanced-control timers (TMR1, TMR8 and TMR20)

### 14.4.1 TMR1, TMR8 and TMR20 introduction

Each of the advanced-control timer (TMR1, TMR8 and TMR20) consists of a 16-bit counter supporting up and down counting modes, four capture/compare registers, and five independent channels to achieve embedded dead-time, input capture and programmable PWM output.

### 14.4.2 TMR1, TMR8 and TMR20 main features

The main functions of general-purpose TMR1, TMR8 and TMR20 include:

- Source of counter clock: internal clock, external clock an internal trigger input
- 16-bit up, down, up/down, repetition and encoder mode counter
- Five independent channels for input capture, output compare, PWM generation, one-pulse mode output and embedded dead-time
- Three independent channels for complementary output
- TMR brake function
- Synchronization control between master and slave timers
- Interrupt/DMA is generated at overflow event, trigger event, brake signal input and channel event
- Support TMR burst DMA transfer

Figure 14-59 Block diagram of advanced-control timer



### 14.4.3 TMR1, TMR8 and TMR20 functional overview

#### 14.4.3.1 Counting clock

The count clock of TMR1, TMR8 and TMR20 can be provided by the internal clock (CK\_INT), external clock (external clock mode A and B) and internal trigger input (ISx).

Figure 14-60 Count clock



### Internal clock (CK\_INT)

By default, the CK\_INT 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 APB; otherwise, it doubles the APB clock frequency.

The configuration process is as follows:

- Configure the CLKDIV[1:0] bit in the TMRx\_CTRL1 register and set CK\_INT frequency.
- Configure the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register and select count mode. If the one-way count direction is set, configure OWCDIR bit in the TMRx\_CTRL1 register to select the specific direction.
- Configure the TMRx\_DIV register and set counting frequency.
- Configure the TMRx\_PR register and set counting period.
- Configure the TMREN bit in the TMRx\_CTRL1 register and enable the counter.

Figure 14-61 Use CK\_INT to drive counter, with 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 with filtering and polarity selection), C2IFP2 (STIS=3'b110, channel 2 signal with filtering and polarity selection) and EXT (STIS=3'b111, external input signal with 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 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 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 14-62 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 14-63 Counting in external clock mode A, with PR=0x32 and DIV=0x0



Figure 14-64 Block diagram of external clock mode B



*Note: The delay between the signal on the input side and the actual clock of the counter is due to the synchronization circuit.*

Figure 14-65 Counting in external clock mode B, with PR=0x32 and DIV=0x0

**Internal trigger input (IS<sub>x</sub>)**

Timer synchronization allows interconnection between several timers. The TMR\_CLK of one timer can be provided by the TRGOUT signal output by another timer. Set the STIS[2:0] bit to select internal trigger signal to enable counting.

Each 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 TMRx\_DIV register. The prescaler value can be modified at any time, but it takes effect only when the next overflow event occurs.

The internal trigger input is configured as follows:

- Set the TMRx\_PR register to set counting period.
- Set the TMRx\_DIV register to set counting frequency.
- Set the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register to set count mode.
- Set the STIS[2:0] bit (range: 3'b000~3'b011) in the TMRx\_STCTRL register and select internal trigger.
- Set SMSEL[2:0]=3'b111 in the TMRx\_STCTRL register and select external clock mode A.
- Set the TMREN bit in the TMRx\_CTRL1 register to enable TMRx counter.

Table 14-12 TMRx internal trigger connection

| Slave timer | IS0 (STIS=000) | IS1 (STIS=001) | IS2 (STIS=010) | IS3 (STIS=011) |
|-------------|----------------|----------------|----------------|----------------|
| TMR1        | TMR5           | TMR2           | TMR3           | TMR4           |
| TMR8        | TMR1           | TMR2           | TMR4           | TMR5           |
| TMR20       | TMR8           | TMR2           | TMR4           | TMR5           |

Figure 14-66 Counter timing with prescaler value changing from 1 to 4



### 14.4.3.2 Counting mode

The advanced-control timer consists of an internal 16-bit counter supporting up, down, up/down counting modes to meet different application scenarios.

The TMRx\_PR register is used to set the counting period. 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. The OVFEN and OVFS bits are used to configure the overflow event.

The TMRx\_DIV register is used to configure the counting frequency. The counter counts once every count clock period (DIV[15:0]+1). Similar to the TMRx\_PR register, when the periodic buffer is enabled, the value in the TMRx\_DIV register is updated to the shadow register at an overflow event.

Reading the TMRx\_CNT register returns to the current counter value, and writing to the TMRx\_CNT register updates the current counter value to the value being written.

An overflow event is generated by default. Set OVFEN=1 in the TMRx\_CTRL1 to disable generation of update events. The OVFS bit in the TMRx\_CTRL1 register is used to select overflow event source. By default, counter overflow/underflow, setting OVFSWTR bit and the reset signal generated by the slave timer controller in reset mode trigger the generation of an overflow event. When the OVFS bit is set, only counter overflow/underflow triggers an overflow event.

Setting TMREN=1 to enable 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 14-67 Counter structure



#### Upcounting mode

Set TWCSEL[1:0]=2'b00 and OWCDIR=1'b0 in the TMRx\_CTRL1 register to enable upcounting mode. In this 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 the OVFIF bit being set to 1. If the overflow event is disabled, the counter is no longer reloaded with the preload value and period value at a counter overflow event; otherwise, the counter is updated with the preload value and period value on an overflow event.

Figure 14-68 Overflow event when PRBEN=0



Figure 14-69 Overflow event when PRBEN=1



### Downcounting mode

Set TWCSEL[1:0]=2'b00 and OWCDIR=1'b1 in the TMRx\_CTRL1 register to enable downcounting mode. In this 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 14-70 Counter timing diagram with internal clock divided by 4



### Up/down counting mode

Set TWCSEL[1:0]≠2'b00 in the TMRx\_CTRL1 register to enable up/down counting mode. In this 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 also used to select the CxIF flag setting method in up/down counting mode. In up/down counting mode 1 (TWCSEL[1:0]=2'b01), CxIF flag can only be set when the counter counts down; in up/down counting mode 2 (TWCSEL[1:0]=2'b10), CxIF flag can only be set when the counter counts up; in up/down counting mode 3 (TWCSEL[1:0]=2'b11), CxIF flag can be set when the counter counts up/down.

*Note: The OWCDIR is read-only in up/down counting mode.*

Figure 14-71 Counter timing diagram with internal clock divided by 1 and TMRx\_PR=0x32



### Repetition counter mode

The TMRx\_RPR register is used to set the counting period of repetition counter. The repetition counter mode is enabled when the repetition counter value is not equal to 0. In this mode, the repetition counter is decremented at each counter overflow (RPR[15:0]+1). 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 14-72 OVFIF in upcounting mode and up/down counting mode

**Encoder interface mode**

To enable the encoder interface mode, write SMSEL[2: 0]= 3'b001/3'b010/3'b011. In this mode, the two inputs (C1IN/C2IN) 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.

Figure 14-73 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 the 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 14-13 Counting direction versus encoder signals

| Active edge       | Level on opposite signal<br>(C1IFP1 to C2IFP2, C2IFP2 to<br>C1IFP1) | C1IFP1signal |          | C2IFP2signal |          |
|-------------------|---------------------------------------------------------------------|--------------|----------|--------------|----------|
|                   |                                                                     | Rising       | Falling  | Rising       | Falling  |
| C1IFP1            | High                                                                | Down         | Up       | No count     | No count |
|                   | Low                                                                 | Up           | Down     | No count     | No count |
| C2IFP2            | High                                                                | No count     | No count | Up           | Down     |
|                   | Low                                                                 | No count     | No count | Down         | Up       |
| C1IFP1 and C2IFP2 | High                                                                | Down         | Up       | Up           | Down     |
|                   | Low                                                                 | Up           | Down     | Down         | Up       |

Figure 14-74 Example of encoder interface mode C



### 14.4.3.3 TMR input function

Each timer of TMR1, TMR8 and TMR20 has four independent channels. Each channel can be configured as input or output.

As input, each channel input signal is handled as follows:

- TMRx\_CHx outputs the pre-processed CxIRAW. The C1INSEL bit is used to select the source of C1IRAW from TMRx\_CH1 or the 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 inputs edge detector, and outputs 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 bit. 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 channel 1's C1IFP1 signal that passed through channel 2 edge detection). 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. It can be used for filtering, selection, division and input capture of input signals.

Figure 14-75 Input/output channel 1 main circuit



Figure 14-76 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 or CxDEN bit are enabled. If the selected trigger signal is detected when the CxIF is set, a capture overflow event occurs. The TMRx\_CxDT register overwrites the recorded value with the current counter value, and the CxRF is set to 1.

To capture the rising edge of C1IN input, following the configuration procedure mentioned below:

- Set C1C=01 in the TMRx\_CxDT register to select the C1IN as channel 1 input.
- Set the filter bandwidth of C1IN signal (CxDF[3: 0]).
- Set the active edge on the C1IN channel by writing C1P=0 (rising edge) in the TMRx\_CCTR register.
- Program the capture frequency division of C1IN signal (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 (TMRx\_CH1, TMRx\_CH2 and TMRx\_CH3) are connected to the channel 1 (selected by setting the C1INSE in the TMRx\_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

The PWM input mode applies to channel 1 and channel 2. To enable this mode, map the C1IN and C2IN to the same TMRx\_CHx, and configure the CxIFPx of channel 1/2 to trigger slave timer controller reset.

The PWM input mode can be used to measure the period and duty cycle of input signal. The period and duty cycle of channel 1 can be measured as follows:

- Set C1C=2'b01 to set C1IN as C1IFP1;
- Set C1P=1'b0 to set C1IFP1 rising edge active;
- Set C2C=2'b10 to set C2IN as C1IFP2;
- Set C2P=1'b1 to set C1IFP2 falling edge active;
- Set STIS=3'b101 to set C1IFP1 as the slave timer trigger signal;
- Set SMSEL=3'b110 to set the slave timer in reset mode;
- Set C1EN=1'b1 and C2EN=1'b1 to enable channel 1 and input capture.

In these configurations, the rising edge of channel 1 input signal triggers capture and saves captured values to the C1DT register, and channel 1 input signal rising edge resets the counter. The falling edge of channel 1 input signal triggers capture and saves captured values to the C2DT register. The period and duty of channel 1 input signal can be calculated through C1DT and C2DT respectively.

Figure 14-77 Example of PWM input mode configuration



Figure 14-78 PWM input mode



#### 14.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. The advanced-control timer output function varies from one channel to one channel.

Figure 14-79 Channel output stage (channel 1 to 3)



Figure 14-80 Channel 4 output stage



#### Output mode

Write  $CxOC[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:** Set  $CxOCTRL=3'b110$  to enable PWM mode A. In upcounting, when  $TMRx\_C1DT > TMRx\_CVAL$ ,  $C1ORAW$  outputs high; otherwise, outputs low. In downcounting, when  $TMRx\_C1DT < TMRx\_CVAL$ ,  $C1ORAW$  outputs low; otherwise, outputs high. To set PWM mode A, the following process is recommended:

- Set the TMRx\_PR register to set PWM period;
- Set the TMRx\_CxDT register to set PWM duty cycle;
- Set CxOCTRL=3'b110 in the TMRx\_CM1/CM2 register to set output mode as PWM mode A;
- Set the TMRx\_DIV register and set the counting frequency;
- Set the TWCMSEL[1:0] bit in the TMRx\_CTRL1 register to set the count mode;
- Set CxP bit and CxCOP bit in the TMRx\_CCTRL register to set output polarity;
- Set CxEN bit and CxCEN bit in the TMRx\_CCTRL register to enable channel output;
- Set the OEN bit in the TMRx\_BRK register to enable TMRx output;
- Set the corresponding GPIO of TMR output channel as the multiplexed mode;
- Set the TMREN bit in the TMRx\_CTRL1 register to enable TMRx counter.
- **PWM mode B:** Set CxOCTRL=3'b111 to enable PWM mode B. In upcounting, when TMRx\_C1DT>TMRx\_CVAL, C1ORAW outputs low; otherwise, outputs high. In downcounting, when TMRx\_C1DT<TMRx\_CVAL, C1ORAW outputs high; otherwise, outputs low.
- **Forced output mode:** Set CxOCTRL=3'b100/101 to enable forced output mode. In this case, the CxORAW is forced to be the programmed level, irrespective of the counter value. Despite this, the channel flag bit and DMA request still depend on the compare result.
- **Output compare mode:** Set CxOCTRL=3'b001/010/011 to enable output compare mode. 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).
- **One-pulse mode:** This is a particular case of PWM mode. Set OCMEN=1 to enable one-pulse mode. 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 as in upcounting mode, the configuration must follow the rule: CVAL<CxDT≤PR; in downcounting mode, CVAL>CxDT is required.
- **Fast output mode:** Set CxOIEN=1 to enable this mode. If enabled, the CxORAW signal will not change when the counter value matches the CxDT, but 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 14-81](#) gives an example of output compare mode (toggle) with C1DT=0x3. When the counter value is equal to 0x3, C1OUT toggles.

[Figure 14-82](#) gives an example of the combination between upcounting mode and PWM mode A. The output signal behaves when PR=0x32 but CxDT is configured with a different value.

[Figure 14-83](#) gives an example of the combination between up/down counting mode and PWM mode A. The output signal behaves when PR=0x32 but CxDT is configured with a different value.

[Figure 14-84](#) gives an example of the combination between upcounting mode and one-pulse PWM mode B. The counter only counts only one cycle, and the output signal sends only one pulse.

Figure 14-81 C1ORAW toggles when counter value matches the C1DT value



Figure 14-82 Upcounting mode and PWM mode A



Figure 14-83 Up/down counting mode and PWM mode A



Figure 14-84 One-pulse mode



### Master timer event output

When TMR is selected as the master timer, the following signal sources can be selected as TRGOUT signal to output to the slave timer, by setting the PTOS bit in the TMRx\_SWEVT register.

- PTOS=3'b000, TRGOUT outputs software overflow event (OVFSWTR bit in the TMRx\_SWEVT register).
- PTOS=3'b001, TRGOUT outputs counter enable signal.

- PTOS=3'b010, TRGOUT outputs counter overflow event.
- PTOS=3'b011, TRGOUT outputs capture and compare event.
- PTOS=3'b100, TRGOUT outputs C1ORAW signal.
- PTOS=3'b101, TRGOUT outputs C2ORAW signal.
- PTOS=3'b110, TRGOUT outputs C3ORAW signal.
- PTOS=3'b111, TRGOUT outputs C4ORAW signal.

### 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 14-85](#) 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 14-85 Clearing CxORAW(PWM mode A) 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 14-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, and if C1OUT and C1COUT do not generate corresponding pulses, the dead-time should be less than the width of the active output.

[Figure 14-86](#) gives an example of dead-time insertion when CxP=0, CxCP=0, OEN=1, CxEN=1 and CxCEN=1.

Figure 14-86 Complementary output with dead-time insertion



### 14.4.3.5 TMR brake function

When the brake function is enabled (BRKEN=1), the CxOUT and CxCOUT are jointly controlled by OEN, FCSOEN, CxSOEN, CxIOS and CxCIOS. But, CxOUT and CxCOUT cannot be set both to active level at the same time. Please refer to 14-15 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 FCSOEN 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 FCSOEN=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. It should be noted that because of synchronization on OEN, the dead-time duration is usually longer than usual (around 2 clk\_tmr clock cycles)
  - If FCSOEN=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 14-87 TMR output control



Figure 14-88 Example of TMR brake function



#### 14.4.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 14-89 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 14-90 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 14-91 Example of trigger mode

**14.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. Refer to Chapter 30.2 for more information.

#### 14.4.4 TMR1, TMR8 and TMR20 registers

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

TMR1 and TMR8 register are mapped into a 16-bit addressable space.

Table 14-14 TMR1, TMR8 and TMR20 register map and reset value

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| TMRx_CTRL1   | 0x00   | 0x0000      |
| TMRx_CTRL2   | 0x04   | 0x0000 0000 |
| TMRx_STCTRL  | 0x08   | 0x0000      |
| TMRx_IDEN    | 0x0C   | 0x0000      |
| TMRxISTS     | 0x10   | 0x0000      |
| TMRx_SWEVT   | 0x14   | 0x0000      |
| TMRx_CM1     | 0x18   | 0x0000      |
| TMRx_CM2     | 0x1C   | 0x0000      |
| TMRx_CCTRL   | 0x20   | 0x0000      |
| TMRx_CVAL    | 0x24   | 0x0000      |
| TMRx_DIV     | 0x28   | 0x0000      |
| TMRx_PR      | 0x2C   | 0x0000      |
| TMRx_RPR     | 0x30   | 0x0000      |
| TMRx_C1DT    | 0x34   | 0x0000      |
| TMRx_C2DT    | 0x38   | 0x0000      |
| TMRx_C3DT    | 0x3C   | 0x0000      |
| TMRx_C4DT    | 0x40   | 0x0000      |
| TMRx_BRK     | 0x44   | 0x0000      |
| TMRx_DMACTRL | 0x48   | 0x0000      |
| TMRx_DMADT   | 0x4C   | 0x0000      |
| TMRx_CM3     | 0x70   | 0x0000      |
| TMRx_C5DT    | 0x74   | 0x0000      |

##### 14.4.4.1 TMR1, TMR8 and TMR20 control register 1 (TMRx\_CTRL1)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 9: 8   | CLKDIV   | 0x0         | rw   | Clock division<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 ratio relationship 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 mode1, count up and down                                                                                                                                                                                                                                                                                                              |

|       |        |     |    |                                                                                                                                                                                                                                                                                                                               |
|-------|--------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     |    | alternately, the output flag bit is set only when the counter counts down<br>10: Two-way counting mode2, count up and down alternately, the output flag bit is set only when the counter counts up<br>11: Two-way counting mode3, count up and down alternately, the output flag bit is set when the counter counts up / 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 use 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: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                       |

#### 14.4.4.2 TMR1, TMR8 and TMR20 control register 2 (TMRx\_CTRL2)

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                              |
|------------|-----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | TRGOUT2EN | 0x0         | rw   | TRGOUT2 enable<br>0: TRGOUT2 remains low<br>1: TRGOUT2 outputs C4ORAW rising edge or C5ORAW falling edge                                                                                                                                 |
| Bit 30: 15 | Reserved  | 0x0000      | resd | Kept at its 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>OEN = 0 after dead-time:<br>0: C1OUTL=0<br>1: C1OUTL=1                                                                                                                                      |
| Bit 8      | C1IOS     | 0x0         | rw   | Channel 1 idle output state<br>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<br>100: C1ORAW signal<br>101: C2ORAW signal<br>110: C3ORAW signal |

|       |          |     |      |                                                                                                                                                                                                                                                   |
|-------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 111: C4ORAW signal                                                                                                                                                                                                                                |
|       |          |     |      | DMA request source                                                                                                                                                                                                                                |
| Bit 3 | DRS      | 0x0 | rw   | 0: Capture/compare event<br>1: Overflow event                                                                                                                                                                                                     |
|       |          |     |      | Channel control bit flash selection                                                                                                                                                                                                               |
| Bit 2 | CCFS     | 0x0 | rw   | 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 its default value.                                                                                                                                                                                                                        |
|       |          |     |      | Channel buffer control                                                                                                                                                                                                                            |
| Bit 0 | CBCTRL   | 0x0 | rw   | 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.                                                                                   |

#### 14.4.4.3 TMR1, TMR8 and TMR20 slave timer control register (TMRx\_STCTRL)

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|--------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 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 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.<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)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

---

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 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 and 14-5 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. |

---

#### 14.4.4.4 TMR1, TMR8 and TMR20 DMA/interrupt enable register (TMRx\_IDEN)

| Bit    | Name     | Reset value | Type | Description                                                    |
|--------|----------|-------------|------|----------------------------------------------------------------|
| Bit 15 | Reserved | 0x0         | resd | Kept at its 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                      |

|       |       |     |    |                                                                       |
|-------|-------|-----|----|-----------------------------------------------------------------------|
|       |       |     |    | 1: Enabled<br>Channel 2 interrupt enable<br>0: Disabled<br>1: Enabled |
| Bit 2 | C2IEN | 0x0 | rw | Channel 1 interrupt enable<br>0: Disabled<br>1: Enabled               |
| Bit 1 | C1IEN | 0x0 | rw | Overflow interrupt enable<br>0: Disabled<br>1: Enabled                |

#### 14.4.4.5 TMR1, TMR8 and TMR20 interrupt status register (TMRx\_ISTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 13 | Reserved | 0x0         | resd | Kept at its 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      | 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<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 OVFG= 1 in the TMRx_SWEVE register;<br>- An overflow event is generated when the counter CVAL is reinitialized by a trigger event. |
|-------|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 14.4.4.6 TMR1, TMR8 and TMR20 software event register (TMRx\_SWEVT)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 8 | Reserved | 0x000       | resd | Kept at its 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     | C4SWTR   | 0x0         | wo   | Channel 4 event triggered by software<br>Please refer to C1M description.                                                                                                                                      |
| Bit 3     | C3SWTR   | 0x0         | wo   | Channel 3 event triggered by software<br>Please refer to C1M description.                                                                                                                                      |
| Bit 2     | C2SWTR   | 0x0         | wo   | Channel 2 event triggered by software<br>Please refer to C1M 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.                                                           |

#### 14.4.4.7 TMR1, TMR8 and TMR20 channel mode register 1 (TMRx\_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 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                                                                                                                                   |
| 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 |

|          |         |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|---------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |         |     |    | 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    | C1OSEN  | 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 6: 4 | C1OCTRL | 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><ul style="list-style-type: none"><li>- OWCDIR=0, C1ORAW is high once TMRx_C1DT&gt;TMRx_CVAL, else low;</li><li>- OWCDIR=1, C1ORAW is low once TMRx_C1DT &lt;TMRx_CVAL, else high;</li></ul> 111: PWM mode B <ul style="list-style-type: none"><li>- OWCDIR=0, C1ORAW is low once TMRx_C1DT &gt;TMRx_CVAL, else high;</li><li>- OWCDIR=1, C1ORAW is high once TMRx_C1DT &lt;TMRx_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 | 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 2    | C1OIEN  | 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.<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: 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

**Input capture mode:**

| Bit        | Name   | Reset value | Type | Description              |
|------------|--------|-------------|------|--------------------------|
| 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  |

|          |        |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|--------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |     |    | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 14.4.4.8 TMR1, TMR8 and TMR20 channel mode register 2 (TMRx\_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 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 |

|          |         |     |    |                                                                                                                                                                                                                                                                                                                                                                     |
|----------|---------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 9: 8 | C4C     | 0x0 | rw | 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 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                                                                                                                                                                                                                                                                                                                                 |
| Bit 1: 0 | C3C     | 0x0 | rw | 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. |

**Input capture mode:**

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                         |
|------------|--------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 12 | C4DF   | 0x0         | rw   | Channel 4 digital filter                                                                                                                                                                                                                                                                                                                                            |
| Bit 11: 10 | C4IDIV | 0x0         | rw   | Channel 4 input divider                                                                                                                                                                                                                                                                                                                                             |
| Bit 9: 8   | C4C    | 0x0         | rw   | 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 7: 4   | C3DF   | 0x0         | rw   | Channel 3 digital filter                                                                                                                                                                                                                                                                                                                                            |
| Bit 3: 2   | C3IDIV | 0x0         | rw   | Channel 3 input divider                                                                                                                                                                                                                                                                                                                                             |
| Bit 1: 0   | C3C    | 0x0         | rw   | 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. |

#### 14.4.4.9 TMR1, TMR8 and TMR20 channel control register (TMRx\_CCTRL)

| Bit        | Name     | Reset value | Type | Description                                                          |
|------------|----------|-------------|------|----------------------------------------------------------------------|
| Bit 15: 14 | Reserved | 0x0         | resd | Kept its 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                                                     |

|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                   |                                   |
|-------|-------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                   | 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.<br>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 14-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-time,<br>Cx_EN=1                                      | CxORAW<br>inverted+polarity+dead-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>CxCEN=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-time,<br>Cx_EN=1                                     | CxORAW<br>inverted+polarity+dead-time,                                        |

|   |   |     |                                                                                                                                                                    |         |
|---|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|   |   |     |                                                                                                                                                                    | CxCEN=1 |
| 0 | 0 | 0 0 | Output disabled<br>(the corresponding IO disconnected from timer, IO floating)                                                                                     |         |
| 0 | 0 | 0 1 | Asynchronously: CxOUT=CxP, Cx_EN=0,<br>CxOUT=CxCP, CxCEN=0;                                                                                                        |         |
| 0 | 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. |         |
| 0 | 1 | 1 1 |                                                                                                                                                                    |         |
| 1 | X | 0 0 | CxEN=CxCEN=0: output disabled (the corresponding<br>IO disconnected from timer, IO floating)                                                                       |         |
| 1 | 1 | 0 1 | Other: Off-state (the corresponding channel outputs<br>inactive level)                                                                                             |         |
| 1 | 1 | 1 0 | Asynchronously: CxOUT =CxP, Cx_EN=1,<br>CxOUT=CxCP, CxCEN=1;                                                                                                       |         |
| 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.

#### 14.4.4.10 TMR1, TMR8 and TMR20 counter value (TMRx\_CVAL)

| Bit       | Name | Reset value | Type | Description   |
|-----------|------|-------------|------|---------------|
| Bit 15: 0 | CVAL | 0x0000      | rw   | Counter value |

#### 14.4.4.11 TMR1, TMR8 and TMR20 division value (TMRx\_DIV)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                              |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

#### 14.4.4.12 TMR1, TMR8 and TMR20 period register (TMRx\_PR)

| Bit       | Name | Reset value | Type | Description                                                                                                            |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | PR   | 0x0000      | rw   | Period value<br>This defines the period value of the TMRx counter. The timer stops working when the period value is 0. |

#### 14.4.4.13 TMR1, TMR8 and TMR20 repetition period register (TMRx\_RPR)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                              |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 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. |

#### 14.4.4.14 TMR1, TMR8 and TMR20 channel 1 data register (TMRx\_C1DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                   |
|-----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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: |

C1DT is the value to be compared with the CVAL value. Whether the written value takes effect immediately depends on the C1OBEN bit, and the corresponding output is generated on C1OUT as configured.

#### 14.4.4.15 TMR1, TMR8 and TMR20 channel 2 data register (TMRx\_C2DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

#### 14.4.4.16 TMR1, TMR8 and TMR20 channel 3 data register (TMRx\_C3DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | C3DT | 0x0000      | rw   | 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).<br>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. |

#### 14.4.4.17 TMR1, TMR8 and TMR20 channel 4 data register (TMRx\_C4DT)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | C3DT | 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 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. |

#### 14.4.4.18 TMR1, TMR8 and TMR20 brake register (TMRx\_BRK)

| Bit    | Name  | Reset value | Type | Description                                                                                                                                              |
|--------|-------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15 | OEN   | 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 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.                                                                                                  |

|          |         |      |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|---------|------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |         |      |    | 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_BRK: 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>TMRx_CMx: C2OCTRL and C2OBEN<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, AOEN, BRKV, BRKEN, FCSODIS, FCSOEN and DTC[7:0] can all be write protected. Thus it is necessary to configure write protection when writing to the TMRx\_BRK register for the first time.

#### 14.4.4.19 TMR1, TMR8 and TMR20 DMA control register (TMRx\_DMACTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                               |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15:13 | Reserved | 0x0         | resd | Kept at its 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 its 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>.....                |

#### 14.4.4.20 TMR1, TMR8 and TMR20 DMA data register (TMRx\_DMADT)

| Bit       | Name  | Reset value | Type | Description                                                                                                                                                                                                   |
|-----------|-------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 |

#### 14.4.4.21 TMR1, TMR8 and TMR20 channel mode register 3 (TMRx\_CM3)

| Bit       | Name     | Reset value | Type | Description                         |
|-----------|----------|-------------|------|-------------------------------------|
| Bit 15: 6 | Reserved | 0x000       | resd | Kept at its default value.          |
| Bit 7     | C5OSEN   | 0x0         | rw   | Channel 5 output switch enable      |
| Bit 6: 4  | C5OCTRL  | 0x0         | rw   | Channel 5 output control            |
| Bit 3     | C5OBEN   | 0x0         | rw   | Channel 5 output buffer enable      |
| Bit 2     | C5OIEN   | 0x0         | rw   | Channel 5 output immediately enable |
| Bit 1: 0  | Reserved | 0x0         | resd | Kept at its default value.          |

#### 14.4.4.22 TMR1, TMR8 and TMR20 channel 5 data register (TMRx\_C5DT)

| Bit       | Register | Reset value | Type | Description                                                                                                                                                                                                                      |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 0 | C5DT     | 0x0000      | rw   | Channel 5 data register<br>C5DT holds the value that is to be compared with the CVAL. Whether the written data will takes effect immediately depends on the C5OBEN bit, and the corresponding output generates on the C5OUT bit. |

# 15 Window watchdog timer (WWDT)

## 15.1 WWDT introduction

The window watchdog downcounter must be reloaded in a limited time window to prevent the watchdog circuits from generating 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.

## 15.2 WWDT main features

- 7-bit downcounter
- If 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.

## 15.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 counter is reloaded while the 7-bit downcounter is greater than the value programmed in the window register.

Figure 15-1 Window watchdog block diagram



To prevent system reset, 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. The WIN[6: 0] bit can be used to configure 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 bit 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 15-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 15-2 Window watchdog timing diagram



## 15.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. Refer to Chapter 30.2 for more information.

## 15.5 WWDT registers

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

Table 15-2 WWDT register map and reset value

| Register  | Offset | Reset value |
|-----------|--------|-------------|
| WWDT_CTRL | 0x00   | 0x7F        |
| WWDT_CFG  | 0x04   | 0x7F        |
| WWDT_STS  | 0x08   | 0x00        |

### 15.5.1 Control register (WWDT\_CTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                              |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x000000    | resd | Kept at its 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.                                               |

### 15.5.2 Configuration register (WWDT\_CFG)

| Bit        | Name     | Reset value | Type | Description                                                                    |
|------------|----------|-------------|------|--------------------------------------------------------------------------------|
| Bit 31: 10 | Reserved | 0x000000    | resd | Kept at its default value.                                                     |
| Bit 9      | RLDIEN   | 0x0         | rw   | 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 |

|          |     |      |    |                                                                                                                                                                      |
|----------|-----|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |     |      |    | 10: PCLK1 divided by 16384<br>11: PCLK1 divided by 32768                                                                                                             |
|          |     |      |    | Window value                                                                                                                                                         |
| Bit 6: 0 | WIN | 0x7F | rw | If the counter is reloaded while its value is greater than the window register value, a reset is generated. The counter must be reloaded between 0x40 and WIN[6: 0]. |

### 15.5.3 Status register (WWDT\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                   |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 1 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                    |
| Bit 0     | RLDF     | 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. |

# 16 Watchdog timer (WDT)

## 16.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.

## 16.2 WDT main features

- 12-bit downcounter
- The counter is clocked by LICK (can work in Stop and Standby modes)
- The counter can be configured to stop counting either in Deepsleep or Standby mode
- 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

## 16.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 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.

### WDT write-protected:

The WDT\_DIV and WDT\_RLD registers are write-protected. Writing the value 0x5555 to the WDT\_CMD register will unlock write protection. The update status of these two registers are indicated by the DIVF and RLDF bits in the WDT\_STS register. If a different value is written to the WDT\_CMD register, these two 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 the LICK. The LICK is an internal RC clock with a typical value of 40kHz, with its range falling between 30kHz and 60kHz. 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 the WDT timeout with a relatively accuracy. For more details, please refer to section 4.1.1.

### 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 perform 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 16-1 WDT block diagram



Table 16-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                                 |

## 16.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 30.2 for more information.

## 16.5 WDT registers

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

Table 16-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 |

### 16.5.1 Command register (WDT\_CMD)

(Reset in Standby mode)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                               |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                |
| Bit 15: 0  | CMD      | 0x0000      | wo   | Command register<br>0xAAAA: Reload counter<br>0x5555: Unlock write-protected WDT_DIV and WDT_RLD<br>0xCCCC: Enable WDT. If the hardware watchdog has been enabled, ignore this operation. |

### 16.5.2 Divider register (WDT\_DIV)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved | 0x0000 0000 | resd | Kept at its 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. |

### 16.5.3 Reload register (WDT\_RLD)

(Reset in Standby mode)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                       |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x00000     | resd | Kept at its 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. |

### 16.5.4 Status register (WDT\_STS)

(Reset in Standby mode)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                         |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 2 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                          |
| Bit 1     | 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 |

### 16.5.5 Window register (WDT\_WIN)

(Reset in Standby mode)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                      |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                       |
| Bit 11 : 0 | WIN      | 0xFFFF      | ro   | Window value<br>When the counter value is greater than the window value, the reload counter will perform a reset. The reload counter value falls between 0 and the window value. |

# 17 Enhanced real-time clock (ERTC)

## 17.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 RTC module is in battery powered domain, which means that it keeps running and free from the influence of system reset and VDD power off as long as VBAT is powered.

## 17.2 ERTC main features

- Real-time calendar (automatic processing of month days, including 28 (February in a common year), 29 (February in a leap year), 30 (a lunar month of 30 days) and 31 (a solar month of 31 days), where the current register being a multiple of 4 indicates a leap year), two programmable alarms
- Periodic auto-wakeup
- Reference clock detection
- Two programmable tamper detection, supporting time stamp feature
- Supports fine calibration and coarse 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-way tamper detection and time stamp

Figure 17-1 ERTC block diagram



## 17.3 ERTC function overview

### 17.3.1 ERTC clock

ERTC clock source (ERTC\_CLK) is selected via clock controller from a LEXT, LICK, and a divided HEXT clock (By setting the ERTCSEL[1: 0] in the CRM\_BPDC register). The HEXT divider value is configured through the ERTC\_DIV[4: 0] bit in the CRM\_CFG register.

The ERTC embeds two dividers: A and B, programmed by the DIVA[6: 0] and DIVB[14: 0] respectively. It is recommended that the DIVA is configured to a higher value in order to minimum power consumption. After being divided by prescaler 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 frequency of ck\_a and ck\_b can be 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: To use a divided HEXT by the ERTC\_CLK, it is necessary to configure a HEXT divider value before switching a clock source to the HEXT.*

### 17.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 it.

To unlock the write protection of ERTC registers, the steps below should be respected:

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 the 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 17-1 lists the ERTC registers that can be configured only after the write protection is unlocked and when the initialization mode is entered.

Table 17-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, bit 6 and 4 only              | -                          |
| ERTC_STS  | Y, except [14: 8] | -                                    | -                          |
| ERTC_DIV  | Y                 | Y                                    | -                          |
| ERTC_WAT  | Y                 | N                                    | Configurable when WATWF=1  |
| ERTC_CCAL | Y                 | Y                                    | -                          |
| ERTC_ALA  | Y                 | N                                    | Configurable when ALAWF =1 |
| ERTC_ALB  | Y                 | N                                    | Configurable when ALAWF =1 |

|             |   |   |                             |
|-------------|---|---|-----------------------------|
| ERTC_WP     | - | - | -                           |
| ERTC_SBS    | - | - | -                           |
| ERTC_TADJ   | Y | N | Configurable when TADJF=0   |
| ERTC_TSTM   | - | - | -                           |
| ERTC_TS DT  | - | - | -                           |
| 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 for clock and calendar initialization:

1. Set the IMEN bit to enter initialization mode
2. Wait until the initialization flag INITF bit is set
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, 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 bit is set, 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. Reference clock detection and coarse digital calibration cannot be used at the same time. Thus when RCDEN=1, coarse digital calibration is not supported.*

### Reading the calendar

The ERTC offers two different ways to read the calendar, that is, synchronous read (DREN=0) and asynchronous read (DREN=1).

In the case of DREN=0, the clock and calendar values can be obtained by reading a 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.

In the case of 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.

To configure the alarm clocks, the following steps should be respected:

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.*

### 17.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+216). 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.

To enable a periodic automatic wakeup, the following steps should be respected:

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 ERTC\_CLK is selected as the wakeup timer, the counter for periodic wakeup works normally..*

### 17.3.4 ERTC calibration

Two calibration methods are available: coarse and fine calibration. But the two calibration methods cannot be used together.

#### **Coarse digital calibration:**

Coarse digital calibration can be used to advance or delay the calendar updates by increasing or decreasing ck\_a cycles.

When positive calibration is enabled (CALDIR=0), 2 ck\_a cycles are added every minute (around 15360 ck\_a cycles) for the first 2xCALVAL minutes of the 64-minute cycle. This causes the calendar to be updated sooner.

When negative calibration is enabled (CALDIR=1), 1 ck\_a cycle is ignored every minute (around ck\_a cycles) for the first 2xCALVAL minutes of the 64-minute cycle. This causes the calendar to be updated later.

*Note: Coarse digital calibration can work correctly only when the DIVA is 6 or above.*

#### **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 220 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 220 ERTC\_CLK cycles. A maximum of 511 pulses can be removed. When the ADD is set, 512 pulses can be inserted during the 220 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 220 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 220 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.

### 17.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 are 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). The clock synchronization cannot be used in conjunction with the coarse digital calibration.

### 17.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) in the ERTC\_STS register will be set. 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.*

### 17.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 respectively. TAMP1 can select either ERTC\_MUX or ERTC\_MUX2 through the TSPIN bit, while the TAMP2 can only select ERTC\_MUX2.

The TP1F or TP2F will be set 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, 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 (either 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 mode, select ERTC\_MUX1 or ERTC\_MUX2 (through the TP1PIN bit), and enable TAMP1 (setting TP1EN=1); To use TAMP2 mode, just need enable TAMP2 (TP2EN=1)

#### How to configure level detection with filter

1. Select level detection with filter, and valid level sampling times (TPFLT≠00)
2. Select tamper detection valid level (through TP1EDG or TP2EDG)
3. Select tamper detection sampling frequency (through the TPFREQ bit )

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 mode, select ERTC\_MUX1 or ERTC\_MUX2 (through the TP1PIN bit), and enable TAMP1 (setting TP1EN=1); To use TAMP2 mode, just need enable TAMP2 (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 still active even when the VDD power is OFF.*

*Note: In Standby mode, TAMP2 (PA0 pin) can not use pre-charge function.*

### 17.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 events (OUTSEL=3)

When alarm clock or wakeup events are 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.

### 17.3.9 ERTC wakeup

ERTC can be woken up by alarm clocks, periodic auto wakeup feature, time stamps or tamper events. To enable an ERTC interrupt, configure as follows:

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 17-2 lists the ERTC clock sources, events and interrupts that are able to wakeup low-power modes.

Table 17-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 17-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  | TPIEN                | 21         |

## 17.4 ERTC registers

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

ERTC registers are 32-bit addressable registers.

Table 17-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_CCAL  | 0x18   | 0x0000 0000 |
| 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 |

### 17.4.1 ERTC time register (ERTC\_TIME)

| Bit        | Name     | Reset value | Type | Description                                                                                                      |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Kept at its default value.                                                                                       |
| Bit 22     | AMPM     | 0x0         | rw   | AM/PM<br>0: AM<br>1: PM<br>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 its default value.                                                                                       |
| Bit 6: 4   | ST       | 0x0         | rw   | Second tens                                                                                                      |
| Bit 3: 0   | SU       | 0x0         | rw   | Second units                                                                                                     |

### 17.4.2 ERTC date register (ERTC\_DATE)

| Bit        | Name     | Reset value | Type | Description                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                  |
| Bit 23: 20 | YT       | 0x0         | rw   | Year tens                                                                                                                   |
| Bit 19: 16 | YU       | 0x0         | rw   | Year units                                                                                                                  |
| Bit 15: 13 | WK       | 0x1         | rw   | 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 12     | MT       | 0x0         | rw   | Month tens                                                                                                                  |
| Bit 11: 8  | MU       | 0x1         | rw   | Month units                                                                                                                 |
| Bit 7: 6   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                  |
| Bit 5: 4   | DT       | 0x0         | rw   | Date tens                                                                                                                   |
| Bit 3: 0   | DU       | 0x1         | rw   | Date units                                                                                                                  |

### 17.4.3 ERTC control register (ERTC\_CTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                          |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at its 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 events |

|        |         |     |    |                                                                                                                                                                                                                                                                                                                                                             |
|--------|---------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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  | CCALEN  | 0x0 | rw | Coarse calibration enable<br>0: Coarse calibration disabled<br>1: Coarse calibration enabled                                                                                                                                                                                                                                                                |
| 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                                                                                                                                                                                                                                                                                                                    |

|          |        |     |    |                                                                                                                                                                                                                                                                                                                                                |
|----------|--------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        |     |    | 1: Falling edge<br>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_b<br>11x: ck_b 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> |
| Bit 2: 0 | WATCLK | 0x0 | rw |                                                                                                                                                                                                                                                                                                                                                |

#### 17.4.4 ERTC initialization and status register (ERTC\_STS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved | 0x0000      | resd | Kept at its 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<br>This bit is automatically set when software writes to the ERTC_SCAL register. It is automatically cleared when a new calibration value is taking into account. When this bit is set, the write access to the ERTC_SCAL register is not allowed. |
| Bit 15     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                         |
| Bit 14     | TP2F     | 0x0         | rw0c | Tamper detection 2 flag<br>0: No tamper event<br>1: Tamper event occurs                                                                                                                                                                                                                                                                                                            |
| Bit 13     | TP1F     | 0x0         | rw0c | Tamper detection 1 flag<br>0: No tamper event<br>1: Tamper event occurs                                                                                                                                                                                                                                                                                                            |
| Bit 12     | TSOF     | 0x0         | rw0c | Timestamp overflow flag<br>0: No timestamp overflow<br>1: Timestamp overflow occurs<br>If a new time stamp event is detected when time stamp flag (TSF) is already set, this bit will be set by hardware.                                                                                                                                                                          |
| Bit 11     | TSF      | 0x0         | rw0c | Timestamp flag<br>0: No timestamp event<br>1: Timestamp event occurs<br>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.<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 occurs<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 occurs<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>When an initialization mode is entered, the calendar stops running.                                                                                                                                                                                                             |

|       |       |     |      |                                                                                                                                                                                                                                                                                           |
|-------|-------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 6 | IMF   | 0x0 | ro   | Enter initialization mode flag<br>0: Initialization mode is not entered<br>1: Initialization mode is entered<br>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).                            |
| Bit 5 | UPDF  | 0x0 | rw0c | Calendar update flag<br>0: Calendar update is in progress<br>1: Calendar update is complete<br>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. |
| Bit 4 | INITF | 0x0 | ro   | Calendar initialization flag<br>0: Calendar has not been initialized<br>1: Calendar has been initialized<br>This bit is set when the calendar year filed (ERTC_DATE) is different from 0. It is cleared when the year is 0.                                                               |
| Bit 3 | TADJF | 0x0 | ro   | Time adjustment flag<br>0: No time adjustment<br>1: Time adjustment is in progress<br>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.                                                |
| 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<br>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                                                                                                                                                      |

#### 17.4.5 ERTC divider register (ERTC\_DIV)

| Bit        | Name     | Reset value | Type | Description                                                |
|------------|----------|-------------|------|------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Kept at its default value.                                 |
| Bit 22: 16 | DIVA     | 0x7F        | rw   | Divider A                                                  |
| Bit 15     | Reserved | 0x0         | resd | Kept at its default value.                                 |
| Bit 14: 0  | DIVB     | 0x00FF      | rw   | Divider B<br>Calendar clock = ERTC_CLK/((DIVA+1)x(DIVB+1)) |

#### 17.4.6 ERTC wakeup timer register (ERTC\_WAT)

| Bit        | Name     | Reset value | Type | Description                |
|------------|----------|-------------|------|----------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value. |
| Bit 15: 0  | VAL      | 0xFFFF      | rw   | Wakeup timer reload value  |

#### 17.4.7 ERTC coarse calibration register (ERTC\_CCAL)

| Bit       | Name     | Reset value | Type | Description                                                                                  |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                   |
| Bit 7     | CALDIR   | 0x0         | rw   | Calibration direction<br>0: Positive calibration<br>1: Negative calibration                  |
| Bit 6: 5  | Reserved | 0x0         | resd | Kept at its default value.                                                                   |
| Bit 4: 0  | CALVAL   | 0x00        | rw   | Calibration value<br>Positive calibration<br>00000: +0 ppm<br>00001: +4 ppm<br>00010: +8 ppm |

11111: +126 ppm  
 Negative calibration  
 00000: -0 ppm  
 00001: -2 ppm  
 00010: -4 ppm  
 ...  
 11111: - 63 ppm

#### 17.4.8 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                                                                                                        |

#### 17.4.9 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                                                                                    |

|            |       |     |    |                                                                               |
|------------|-------|-----|----|-------------------------------------------------------------------------------|
|            |       |     |    | 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                                                                  |

#### 17.4.10 ERTC write protection register (ERTC\_WP)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                             |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x000000    | resd | Kept at its default value                                                                                                                               |
| Bit 7: 0  | CMD      | 0x00        | wo   | Command register<br>All ERTC register write protection is unlocked by writing 0xCA and 0x53. Writing any other value will re-activate write protection. |

#### 17.4.11 ERTC subsecond register (ERTC\_SBS)

| Bit        | Name     | Reset value | Type | Description                                                                                         |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its 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) |

#### 17.4.12 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 its 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))                              |

#### 17.4.13 ERTC time stamp time register (ERTC\_TSTM)

| Bit        | Name     | Reset value | Type | Description                                                                                                         |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x000       | resd | Kept at its 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 its 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.*

### 17.4.14 ERTC time stamp date register (ERTC\_TS DT)

| Bit        | Name     | Reset value | Type | Description               |
|------------|----------|-------------|------|---------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its 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 its 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.*

### 17.4.15 ERTC time stamp subsecond register (ERTC\_TSSBS)

| Bit        | Name     | Reset value | Type | Description               |
|------------|----------|-------------|------|---------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its 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.*

### 17.4.16 ERTC smooth calibration register (ERTC\_SCAL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its 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 its 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 periods. This bit is usually used with ADD. When the ADD is set, the actual number of ERTC_CLK is equal to $2^{20}+512-DEC$ during the $2^{20}$ ERTC_CLK periods. |

### 17.4.17 ERTC tamper configuration register (ERTC\_TAMP)

| Bit        | Name     | Reset value | Type | Description                                                        |
|------------|----------|-------------|------|--------------------------------------------------------------------|
| Bit 31: 19 | Reserved | 0x0000      | resd | Kept at its default value                                          |
| Bit 18     | OUTTYPE  | 0x0         | rw   | Output type<br>0: Open-drain output<br>1: Push-pull output         |
| Bit 17     | TSPIN    | 0x0         | rw   | Time stamp detection pin selection<br>0: ERTC_MUX1<br>1: ERTC_MUX2 |
| Bit 16     | TP1PIN   | 0x0         | rw   | Tamper detection pin selection<br>0: ERTC_MUX1<br>1: ERTC_MUX2     |
| Bit 15     | TPPU     | 0x0         | rw   | Tamper detection pull-up<br>0: Tamper detection pull-up enabled    |

|            |          |     |      |                                                                                                                                                             |
|------------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |     |      | 1: Tamper detection pull-up disabled                                                                                                                        |
|            |          |     |      | Tamper detection pre-charge time                                                                                                                            |
|            |          |     |      | 0: 1 ERTC_CLK cycle                                                                                                                                         |
| Bit 14: 13 | TPPR     | 0x0 | rw   | 1: 2 ERTC_CLK cycles<br>2: 4 ERTC_CLK cycles<br>3: 8 ERTC_CLK cycles                                                                                        |
|            |          |     |      | Tamper detection filter time                                                                                                                                |
|            |          |     |      | 0: No filter                                                                                                                                                |
| Bit 12: 11 | TPFLT    | 0x0 | rw   | 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                                                                                                                                  |
|            |          |     |      | 0: ERTC_CLK/32768                                                                                                                                           |
|            |          |     |      | 1: ERTC_CLK/16384                                                                                                                                           |
|            |          |     |      | 2: ERTC_CLK/8192                                                                                                                                            |
| Bit 10: 8  | TPFREQ   | 0x0 | rw   | 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 its default value                                                                                                                                   |
|            |          |     |      | Tamper detection 2 valid edge                                                                                                                               |
|            |          |     |      | If TPFLT=0:<br>0: Rising edge<br>1: Falling edge                                                                                                            |
| Bit 4      | TP2EDG   | 0x0 | rw   | If TPFLT>0:<br>0: Low<br>1: High                                                                                                                            |
|            |          |     |      | 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                                                                                                                               |
|            |          |     |      | If TPFLT=0:<br>0: Rising edge<br>1: Falling edge                                                                                                            |
| Bit 1      | TP1EDG   | 0x0 | rw   | If TPFLT>0:<br>0: Low<br>1: High                                                                                                                            |
|            |          |     |      | Tamper detection 1 enable                                                                                                                                   |
| Bit 0      | TP1EN    | 0x0 | rw   | 0: Tamper detection 1 disabled<br>1: Tamper detection 1 enabled                                                                                             |

### 17.4.18 ERTC alarm clock A subsecond register (ERTC\_ALASBS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 28 | Reserved | 0x0         | resd | Kept at its 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                                                                                                                                                                                                                    |

### 17.4.19 ERTC alarm clock B subsecond register (ERTC\_ALBSBS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 28 | Reserved | 0x0         | resd | Kept at its default value                                                                                                                                                                                                           |
|            |          |             |      | Sub-second mask<br>0: No comparison. Alarm B 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                                                                                                                                                                                                                    |

### 17.4.20 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_{BAT}$ 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. |

# 18 Analog-to-digital converter (ADC)

## 18.1 ADC introduction

The ADC is a peripheral that converts an analog input signal into a 12-bit/10-bit/8-bit/6-bit digital signal. Its sampling rate is as high as 5.33 MSPS. Each ADC has up to 19 channels (internal + external) for sampling and conversion, totaling 24 external channel sources for three ADCs.

## 18.2 ADC main features

In terms of analog:

- 12-bit, 10-bit, 8-bit or 6-bit configurable resolution
- Self-calibration time: 205 ADC clock cycles
- ADC conversion time
  - Fast channel: ADC conversion time is 0.1875  $\mu$ s at 80 MHz in 12-bit resolution (5.33MSps)
  - Slow channel: ADC conversion time is 0.2375  $\mu$ s at 80 MHz in 12-bit resolution (4.21MSps)
  - Fast channel: ADC conversion time is 0.1126  $\mu$ s at 80 MHz in 6-bit resolution (8.88MSps)
  - Slow channel: ADC conversion time is 0.1626  $\mu$ s at 80 MHz in 6-bit resolution (6.15MSps)
- ADC supply requirement: Refer to AT32F435/437 datasheet for more information
- 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
- Oversampling: hardware oversampling up to 16-bit resolution
- Optional data alignment mode
- Programmable voltage monitor threshold
- Regular channels with DMA transfers
- Interrupt generation at one of the following events:
  - Conversion overflow of regular channels
  - End of the conversion of preempted channels
  - End of the conversion of regular channels
  - Voltage outside the threshold programmed
- ADC master/slave modes
- Master/slave shift mode with programmable timing shift length between ADCs
  - Master-slave mode with DMA is suited to high-performance requirements

## 18.3 ADC structure

Figure 18-1 shows the block diagram of ADC1.

Differences between ADC2/ADC3 and ADC1:

1. ADC2/ADC3 are not connected to the internal temperature sensor (Temp. sensor) and internal reference voltage ( $V_{INTRV}$ ) and battery voltage ( $V_{BAT}$ ).

Figure 18-1 ADC1 block diagram



Input pin description:

- V<sub>DDA</sub>: Analog supply, ADC analog supply
- V<sub>SSA</sub>: Analog supply ground, ADC analog supply ground
- V<sub>REF+</sub>: Analog reference positive, high/positive reference voltage for the ADC
- V<sub>REF-</sub>: Analog reference negative, low/negative reference voltage for the ADC
- ADCx\_IN: Analog input signal channels

Refer to the Datasheet for more information about the input pin connections and voltage ranges.

## 18.4 ADC functional overview

### 18.4.1 Channel management

#### Analog signal channel input:

There are 19 analog signal channel inputs for each of the ADCs, expressed by ADC\_Inx (x=0 to 18).

- ADC1\_IN0 to ADC1\_IN15 are referred to as the external analog input, ADC1\_IN16 as an internal temperature sensor, ADC1\_IN17 as an internal reference voltage, and ADC1\_IN18 as a battery voltage.
- ADC2\_IN0 to ADC2\_IN15 are referred to as the external analog input, and ADC2\_IN16 and ADC2\_IN17 as V<sub>SS</sub>, and ADC1\_IN18 as V<sub>REF-</sub>.
- ADC3\_IN0 to ADC3\_IN3, and ADC3\_IN10 to ADC3\_IN13 are referred to as the external analog input, and ADC3\_IN16 and ADC3\_IN17 as V<sub>SS</sub>, and ADC3\_IN18 as V<sub>REF-</sub>.

#### 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 the 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.

#### 18.4.1.1 Internal temperature sensor

The temperature sensor is connected to ADC1\_IN16. Before the temperature sensor channel conversion, it is required to enable the ITSRVEN bit in the ADC\_CCTRL register and wait after power-on time.

Obtain the temperature using the following formula:

$$\text{Temperature (in } ^\circ\text{C)} = \{(V_{25} - V_{\text{SENSE}}) / \text{Avg\_Slope}\} + 25.$$

Where,

V<sub>25</sub> = V<sub>SENSE</sub> value for 25°C and

Avg\_Slope = Average Slope for curve between Temperature vs. V<sub>SENSE</sub> (given in mV/°C).

#### 18.4.1.2 Internal reference voltage

The internal reference voltage of the typical value 1.2 V is connected to ADC1\_IN17. It is required to enable the ITSRVEN bit in the ADC\_CCTRL register before the internal reference channel conversion. The converted data of such channel can be used to calculate the external reference voltage.

#### 18.4.1.3 Battery voltage

V<sub>BAT</sub> is higher than V<sub>DDA</sub>. Thus the V<sub>BAT</sub> must be divided by 4 before being connected to the ADC1\_IN18. The conversion of battery voltage channels starts only when the VBATEN bit is set in the ADC\_CCTRL register in order to power the divided-by-4 circuit.

*Note: When the ADC is used for sampling VBAT voltage, the VBAT keeps consuming as long as the VBATEN is set. Thus it is recommended to enable VBAT only during the sampling period, and disable it at the end of the sampling in order to lower power consumption.*

#### 18.4.2 ADC operation process

Figure 18-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 18-2 ADC basic operation process



### 18.4.2.1 Power-on and calibration

#### Power-on

Set the ADCxEN 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. The ADCCLK is derived from HCLK frequency division.

*Note: ADCCLK must be less than 80 MHz, while the ADCCLK frequency must be lower than PCLK2.*

Then set the ADCEN bit in the ADC\_CTRL2 register to supply the ADC, and wait until the RDY flag is set before starting ADC conversion. Clear the ADCEN bit will stop the ADC conversion and result in a reset. In the meantime, the ADC is switched off to save power.

#### Calibration

After power-on, the 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 performed by software trigger.

After each calibration, the calibration value is stored in the least significant 7 bits of the ADC\_CALVAL register, and then value is automatically sent back to the ADC so as to eliminate capacitance errors. The storage of the calibration value will not set the OCCE flag, or generate interrupts or DMA requests.

*Note: Calibration is permitted only in 12-bit resolution mode. Switching resolution can be made only after the completion of calibration. Then, it is necessary to wait until the RDY flag is set before trigger operation.*

Figure 18-3 ADC power-on and calibration



#### 18.4.2.2 Trigger

The ADC triggers contain ordinary channel trigger and preempted channel trigger. The ordinary channel conversion is triggered by ordinary channel triggers while the preempted channel conversion is triggered by preempted ones. The valid polarity for external trigger sources can be selected by the OCTESEL and PCTESEL bits in the ADC\_CTRL2 register. The ADC starts conversion after a trigger source is detected.

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 and pin triggers. The OCTESEL and PCTESEL bits in the ADC\_CTRL2 register are used to select specific trigger sources, as shown in Table 18-1 and Table 18-2.

Table 18-1 Trigger sources for ordinary channels

| OCTESEL | Trigger source            | OCTESEL | Trigger source      |
|---------|---------------------------|---------|---------------------|
| 00000   | TMR1_CH1 event            | 10000   | TMR20_TRGOUT event  |
| 00001   | TMR1_CH2 event            | 10001   | TMR20_TRGOUT2 event |
| 00010   | TMR1_CH3 event            | 10010   | TMR20_CH1 event     |
| 00011   | TMR2_CH2 event            | 10011   | TMR20_CH2 event     |
| 00100   | TMR2_CH3 event            | 10100   | TMR20_CH3 event     |
| 00101   | TMR2_CH4 event            | 10101   | TMR8_TRGOUT2 event  |
| 00110   | TMR2_TRGOUT event         | 10110   | TMR1_TRGOUT2 event  |
| 00111   | TMR3_CH1 event            | 10111   | TMR4_TRGOUT event   |
| 01000   | TMR3_TRGOUT event         | 11000   | TMR6_TRGOUT event   |
| 01001   | TMR4_CH4 event            | 11001   | TMR3_CH4 event      |
| 01010   | TMR5_CH1 event            | 11010   | TMR4_CH1 event      |
| 01011   | TMR5_CH2 event            | 11011   | TMR1_TRGOUT event   |
| 01100   | TMR5_CH3 event            | 11100   | TMR2_CH1 event      |
| 01101   | TMR8_CH1 event            | 11101   | Reserved            |
| 01110   | TMR8_TRGOUT event         | 11110   | TMR7_TRGOUT event   |
| 01111   | EXINT line11 External pin | 11111   | Reserved            |

Table 18-2 Trigger sources for preempted channels

| PCTESEL | Trigger source            | PCTESEL | Trigger source      |
|---------|---------------------------|---------|---------------------|
| 00000   | TMR1_CH4 event            | 10000   | TMR20_TRGOUT event  |
| 00001   | TMR1_TRGOUT event         | 10001   | TMR20_TRGOUT2 event |
| 00010   | TMR2_CH1 event            | 10010   | TMR20_CH4 event     |
| 00011   | TMR2_TRGOUT event         | 10011   | TMR1_TRGOUT2 event  |
| 00100   | TMR3_CH2 event            | 10100   | TMR8_TRGOUT event   |
| 00101   | TMR3_CH4 event            | 10101   | TMR8_TRGOUT2 event  |
| 00110   | TMR4_CH1 event            | 10110   | TMR3_CH3 event      |
| 00111   | TMR4_CH2 event            | 10111   | TMR3_TRGOUT event   |
| 01000   | TMR4_CH3 event            | 11000   | TMR3_CH1 event      |
| 01001   | TMR4_TRGOUT event         | 11001   | TMR6_TRGOUT event   |
| 01010   | TMR5_CH4 event            | 11010   | TMR4_CH4 event      |
| 01011   | TMR5_TRGOUT event         | 11011   | TMR1_CH3 event      |
| 01100   | TMR8_CH2 event            | 11100   | TMR20_CH2 event     |
| 01101   | TMR8_CH3 event            | 11101   | Reserved            |
| 01110   | TMR8_CH4 event            | 11110   | TMR7_TRGOUT event   |
| 01111   | EXINT line15 External pin | 11111   | Reserved            |

### 18.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. Channels 0/1/10/11/12/13 are fast channels with a minimum of 2.5 sampling cycles, and others represent slow ones supporting a minimum of 6.5 sampling cycles.

The resolution can be programmed through the CRSEL bit in the ADC\_CTRL1 register. A lower resolution has shorter conversion time. A single one conversion time is calculated with the following formula:

$$\text{A single one conversion time (ADCCLK period)} = \text{sampling time} + \text{resolution bits} + 0.5$$

Example:

If the CSPTx selects 2.5 period, and CRSEL select 12-bit resolution, then one conversion needs  $2.5+12.5=15$  ADCCLK periods

If the CSPTx selects 6.5 period, and CRSEL select 10-bit resolution, then one conversion needs  $6.5+10.5=17$  ADCCLK periods.

### 18.4.3 Conversion sequence management

Only one channel is converted at each trigger event by default, that is, OSN1-defined channel or PSN4-defined channel.

The detailed conversion sequence modes are described in the following sections. With this, the channels can be converted in a specific order.

#### 18.4.3.1 Sequence mode

The sequence mode is enabled by setting the SQEN bit in the ADC\_CTRL1 register. The ADC\_OSQx registers are used to configure the sequence and total number of the ordinary channels while the ADC\_PSQ register is used to define the sequence and total number of the preempted channels. When 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 18-4 Sequence mode



#### 18.4.3.2 Automatic preempted group conversion mode

The automatic preempted group conversion mode is enabled by setting the PCAUTOEN bit in the ADC\_CTRL1 register. Once the ordinary channel conversion is over, the preempted group will automatically continue its conversion. This mode can work with the sequence mode. The preempted group conversion starts automatically at the end of the conversion of the ordinary group. Figure 18-5 shows an example of the behavior when the automatic preempted group conversion mode works with the ordinary group.

Figure 18-5 Preempted group auto conversion mode



#### 18.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 with the ordinary channel conversion in the 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 18-6 shows an example of the behavior when the repetition mode works with the sequence mode and preempted group auto conversion mode.

Figure 18-6 Repetition mode



#### 18.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 a smaller sub-group, in which the number of the channels is programmed with the OCPCNT bit in the ADC\_CTRL1 register. A single trigger event will enable the conversion of all the channels in the sub-group. Each trigger event selects different sub-group in order.

Set the PCPEN bit in the ADC\_CTRL1 register will enable the partition mode of the preempted group. In this mode, the preempted group conversion sequence length (PCLEN bit in the ADC\_OSQ1 register) is divided into a sub-group with only one channel. A single one trigger event will enable the conversion of all the channels in the sub-group. Each trigger event selects different sub-group in order.

The partition mode cannot be used with the repetition mode at the same time. Figure 18-7 shows an example of the behavior in partition mode for ordinary group and preempted group.

Figure 18-7 Partition mode



#### 18.4.4 End of conversion

The ADABRT bit in the ADC\_CTRL2 register can be used to stop ADC conversions. At the end of the conversions, the conversion sequence returns to the first channel. This allows the user to configure a new channel sequence, and the ADC starts conversions from the beginning based on the new order when a trigger event occurs. If the ADABRT is set, it is necessary to wait until it is cleared by hardware before starting other ADC operations. Figure 18-8 shows the timing diagram when the ADABRT bit is set.

Figure 18-8 ADABRT timing diagram



### 18.4.5 Oversampling

A single oversampling converted data can be done through multiple conversions of the same channel in which the cumulative converted data is averaged.

- Oversampling ratio is selected through the OSRSEL bit in the ADC\_OVSP register. This bit is used to specify the oversampling multiple, which is performed by converting the same channel several times
- Oversampling shift is selected through the OSSSEL bit in the ADC\_OVSP register, which is performed by right shift

If the averaged data is greater than 16 bits, then only pick up the right-aligned 16-bit data and put them into a 16-bit data register, shown in Table 18-3.

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 OSSSEL bit, then the cumulative data is divided by  $2^6$  and rounded up.

Table 18-3 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 digit         | 0x0FFF | 0x1FFE | 0x3FFC | 0x7FF8  | 0xFFFF0 | 0x1FFE0 | 0x3FFC0 | 0x7FF80  |
| Shift 2 digits        | 0x0800 | 0x0FFF | 0x1FFE | 0x3FFC  | 0x7FF8  | 0xFFFF0 | 0x1FFE0 | 0x3FFC0  |
| Shift 3 digits        | 0x0400 | 0x0800 | 0x0FFF | 0x1FFE  | 0x3FFC  | 0x7FF8  | 0xFFFF0 | 0x1FFE0  |
| Shift 4 digits        | 0x0200 | 0x0400 | 0x0800 | 0x0FFF  | 0x1FFE  | 0x3FFC  | 0x7FF8  | 0xFFFF0  |
| Shift 5 digits        | 0x0100 | 0x0200 | 0x0400 | 0x0800  | 0x0FFF  | 0x1FFE  | 0x3FFC  | 0x7FF8   |
| Shift 6 digits        | 0x0080 | 0x0100 | 0x0200 | 0x0400  | 0x0800  | 0x0FFF  | 0x1FFE  | 0x3FFC   |
| Shift 7 digits        | 0x0040 | 0x0080 | 0x0100 | 0x0200  | 0x0400  | 0x0800  | 0x0FFF  | 0x1FFE   |
| Shift 8 digits        | 0x0020 | 0x0040 | 0x0080 | 0x0100  | 0x0200  | 0x0400  | 0x0800  | 0x0FFF   |

When using oversampling conversion mode, the DTALIGN and PCDTOx are ignored, and data must be right aligned. The CRSEL bit is used to select the desired oversampling resolution only, without changing the data operation mode.

### 18.4.5.1 Oversampling of ordinary group of channels

- The OOSRSEL bit in the ADC\_OVSP register can be used to resume 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.

Figure 18-9 shows the differences between ordinary continuous modes and restart mode in 4x oversampling rate and sequential mode.

Figure 18-9 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 ordinary channels.

When the trigger mode works together with conversion sequence management mode, trigger mode is applied, and the conversion complete flag follows the conversion sequence management mode. Figure 18-10 shows the behavior when the ordinary trigger mode works together with resume mode in 4x oversampling rate and sequential mode.

*Note: It is not possible to use both the trigger mode and repetition mode simultaneously.*

Figure 18-10 Ordinary oversampling trigger mode



### 18.4.5.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 the ordinary oversampling modes. Figure 18-11 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 18-11 Oversampling of preempted group of channels



### 18.4.6 Data management

At the end of the conversion of the ordinary group, the converted value is stored in the ADC\_ODT register. Once the preempted group conversion ends, the converted data of the preempted group is stored in the ADC\_PDTx register.

#### 18.4.6.1 Data alignment

DTALIGN bit in the ADC\_CTRL2 register selects the alignment of data (right-aligned or left-aligned). Apart from this, the converted data of the preempted group is decreased by the offset written in the ADC\_PCDTOx register. Thus the result may be a negative value, marked by SIGN.

The data are aligned on a half-word basis expect when the resolution is set to 6-bit. In this case, the data are aligned on a byte basis, as shown in Figure 18-12.

Figure 18-12 Data alignment

| Ordinary channel data 12 bits  |  |  |  |  |  |  |  |        |        |        |       |        |        |       |       |
|--------------------------------|--|--|--|--|--|--|--|--------|--------|--------|-------|--------|--------|-------|-------|
| Right-alignment                |  |  |  |  |  |  |  | DT[11] | DT[10] | DT[9]  | DT[8] | DT[7]  | DT[6]  | DT[5] | DT[4] |
| Left-alignment                 |  |  |  |  |  |  |  | DT[11] | DT[10] | DT[9]  | DT[8] | DT[7]  | DT[6]  | DT[5] | DT[4] |
| Ordinary channel data 6 bits   |  |  |  |  |  |  |  |        |        |        |       |        |        |       |       |
| Right-alignment                |  |  |  |  |  |  |  | 0      | 0      | 0      | 0     | 0      | 0      | 0     | DT[5] |
| Left-alignment                 |  |  |  |  |  |  |  | 0      | 0      | 0      | 0     | 0      | 0      | 0     | DT[5] |
| Preempted channel data 12 bits |  |  |  |  |  |  |  |        |        |        |       |        |        |       |       |
| Right-alignment                |  |  |  |  |  |  |  | SIGN   | SIGN   | SIGN   | SIGN  | DT[11] | DT[10] | DT[9] | DT[8] |
| Left-alignment                 |  |  |  |  |  |  |  | SIGN   | DT[11] | DT[10] | DT[9] | DT[8]  | DT[7]  | DT[6] | DT[5] |
| Preempted channel data 6 bits  |  |  |  |  |  |  |  |        |        |        |       |        |        |       |       |
| Right-alignment                |  |  |  |  |  |  |  | SIGN   | SIGN   | SIGN   | SIGN  | SIGN   | SIGN   | SIGN  | SIGN  |
| Left-alignment                 |  |  |  |  |  |  |  | SIGN   | SIGN   | SIGN   | SIGN  | SIGN   | SIGN   | SIGN  | SIGN  |

#### 18.4.6.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.

The EOCSFEN bit in the ADC\_CTRL2 register can be used to select when to set the ordinary group conversion complete flag, that is, at the end of sequence mode or each time the ordinary data register is updated.

When the OCDMAEN bit is set in the ADC\_CTRL2 register, the ADC will issue DMA requests each time the ADC\_ODT register is updated.

When the EOCSFEN or OCDMAEN is set, the ADC will automatically start overflow detection. If an overflow event occurs, the OCCO flag will be set, the ADC stops conversion, and the last valid data is stored in the data register. If the DMA is used, the DMA request remains set so that the DMA can read the last valid data. The OCCO flag is cleared by software, and the ADC is triggered again so that it starts conversion from the next channel of the valid data. In this case, even if an overflow event occurs halfway, all the data read are valid and in order.

The OCDRCEN bit in the ADC\_CTRL2 register can be used to select whether to continually send DMA requests after the DMA transfer register is reset.

#### 18.4.7 Voltage monitoring

The OCMEN 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[11:0] register) or is less than the low threshold (ADC\_VMLB[11:0]register).

In 10-bit resolution, ADC\_VMHB[11:10] and ADC\_VMLB[11:10] must be set to 2'b00;

In 8-bit resolution, ADC\_VMHB[11:8] and ADC\_VMLB[11:8] must be set to 4'b0000;

In 6-bit resolution, ADC\_VMHB[11:6] and ADC\_VMLB[11:6] must be set to 6'b000000;

The VMSGEN bit in the ADC\_CTRL1 register is used to enable voltage monitor on either a single channel or all the channels. The VMCSEL bit is used to select a specific channel that requires voltage monitoring.

Voltage monitoring is based on the comparison result between the original converted data and the 12-bit voltage monitor boundary register, irrespective of the CRSEL, PCDTOx and DTALIGN bits.

When using an oversampler, voltage monitoring is based on the comparison result between the 16-bit registers (ADC\_VMHB[15:0] and ADC\_VMLB[15:0]) and the oversampled data.

#### 18.4.7.1 Status flag and interrupts

Each of the ADCs has its dedicated ADC<sub>x</sub>\_STS registers, that is, RDY flag, OCCO flag, OCCS (ordinary channel conversion start flag), PCCS (preempted channel conversion start flag), PCCE (preempted channel conversion end flag), OCCE (ordinary channel conversion end flag) and VMOR (voltage monitor out of range).

Three ADC<sub>x</sub>\_STS registers are mapped onto the ADC\_CSTS register, so it is possible to obtain the status of these tree registers by simply reading the ADC\_CSTS register.

OCCO, 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. ADC1 shares an interrupt vector with ADC2 and ADC3.

### 18.5 Master/Slave mode

If Master/Slave mode is enabled, the master is triggered to work with the slave to do the channel conversion. The ADC\_ODT register is used as a single interface obtaining the ordinary channel converted data of master/slave ADC.

In a single master/slave mode, ADC1 acts as a master while ADC2 as a slave, and ADC3 behaves independently. In dual master/slave mode, ADC1 acts as a master, while both ADC2 and ADC3 act as slaves. In master/slave mode, it is necessary to disable the edge trigger mode of slave ADC.

*Note: ADC conversion abort (ADABRT) cannot be used in master/slave mode. In this mode, each of the ADCEN bit of the ADCs must be cleared in order to stop ADC conversions.*

*Note: Both the master and slave must have the same resolution in order to avoid losing synchronization between master and slave.*

*Note: To enable several ADC conversions with low resolution simultaneously, it is recommended to use the master/slave mode together with DMA1 or DMA2.*

Figure 18-13 Block diagram of master/slave mode



## 18.5.1 Data management

In Master/Slave mode, the converted data of ordinary channels is also stored in the ADC\_CODT register. The MSDMASEL bit in the ADC\_CCTRL register can be used to select from five DMA transfer modes, as shown in Table 18-4. As long as the MSDMASEL is set, the ADC1 DMA channel is used to generate a DMA request each time the data is ready, and overflow detection on master/slave is also enabled. Once an overflow event occurs, the ADC will stop conversion, the DMA request is halted, and loss of synchronization may happen between the master and slave, so it is recommended to re-initialize ADC before re-triggering on an overflow event.

Table 18-4 Master/slave DMA mode

| MSDMASEL | Master/slave mode | DMA requests | ADC_CODT[31:0]                                       |
|----------|-------------------|--------------|------------------------------------------------------|
| 001      | Single slave      | 1st          | 16 bit 0, ADC1_ODT[15:0]                             |
|          |                   | 2nd          | 16 bit 0, ADC2_ODT[15:0]                             |
|          |                   | 3rd          | 16 bit 0, ADC1_ODT[15:0]                             |
|          | Dual slave        | 1st          | 16 bit 0, ADC1_ODT[15:0]                             |
|          |                   | 2nd          | 16 bit 0, ADC2_ODT[15:0]                             |
|          |                   | 3rd          | 16 bit 0, ADC3_ODT[15:0]                             |
|          |                   | 4th          | 16 bit 0, ADC1_ODT[15:0]                             |
| 010      | Single slave      | 1st          | ADC2_ODT[15:0], ADC1_ODT[15:0]                       |
|          |                   | 2nd          | ADC2_ODT[15:0], ADC1_ODT[15:0]                       |
|          | Dual slave        | 1st          | ADC2_ODT[15:0], ADC1_ODT[15:0]                       |
|          |                   | 2nd          | ADC1_ODT[15:0], ADC3_ODT[15:0]                       |
|          |                   | 3rd          | ADC3_ODT[15:0], ADC2_ODT[15:0]                       |
|          |                   | 4th          | ADC2_ODT[15:0], ADC1_ODT[15:0]                       |
|          | Single slave      | 1st          | 16 bit 0, ADC2_ODT[7:0], ADC1_ODT[7:0]               |
|          |                   | 2nd          | 16 bit 0, ADC2_ODT[7:0], ADC1_ODT[7:0]               |
| 011      | Dual slave        | 1st          | 16 bit 0, ADC2_ODT[7:0], ADC1_ODT[7:0]               |
|          |                   | 2nd          | 16 bit 0, ADC1_ODT[7:0], ADC3_ODT[7:0]               |
|          |                   | 3rd          | 16 bit 0, ADC3_ODT[7:0], ADC2_ODT[7:0]               |
|          |                   | 4th          | 16 bit 0, ADC2_ODT[7:0], ADC1_ODT[7:0]               |
|          | Dual slave        | 1st          | 8 bit 0, ADC3_ODT[7:0], ADC2_ODT[7:0], ADC1_ODT[7:0] |
|          |                   | 2nd          | 8 bit 0, ADC3_ODT[7:0], ADC2_ODT[7:0], ADC1_ODT[7:0] |
| 101      | Dual slave        | 1st          | ADC2_ODT[15:0], ADC1_ODT[15:0]                       |
|          |                   | 2nd          | 16 bit 0, ADC3_ODT[15:0]                             |
|          |                   | 3rd          | ADC2_ODT[15:0], ADC1_ODT[15:0]                       |

MSDRcen bit in the ADC\_CCTRL register can be used to select when to stop DMA request, that is, when the DMA request remains set until the end of data transfer, or when the DMA transfer register is reset.

## 18.5.2 Simultaneous mode

### Regular simultaneous mode

MSSEL bit in the ADC\_CCTRL register is used to select regular simultaneous mode. If this mode is enabled, the regular channels of the master are triggered so that both the master and the slave convert the regular channels simultaneously. In this mode, it is required to configure the same sampling time and the same sequence length for the master and slave to avoid the loss of data due to the lack of synchronization.

Figure 18-14 shows an example of the regular simultaneous mode

The single slave mode can work with the mode 1/2/3 of the transfer mode (MSDMASEL), while the dual slave mode can work with the mode 1/4/5.

*Note: The same channel is not allowed to be sampled by several ADCs simultaneously. Do not put the same channel in the same sequence location of different ADCs.*

Figure 18-14 Regular simultaneous mode

**Preempted simultaneous mode**

MSSEL bit in the ADC\_CCTRL register is used to select preempted simultaneous mode. If this mode is enabled, the preempted channels of the master is triggered so that both the master and the slave convert the preempted channels simultaneously. Figure 18-15 shows an example of the preempted simultaneous mode

*Note: The same channel is not allowed to be sampled by several ADCs simultaneously. Do not put the same channel in the same sequence location of different ADCs.*

Figure 18-15 Preempted simultaneous mode

**Combined regular/preempted simultaneous mode**

MSSEL bit in the ADC\_CCTRL register is used to select combined regular/preempted simultaneous mode. If this mode is enabled, the regular channels of the master is triggered so that the master works with the slave to convert the regular channels simultaneously, or the preempted channels of the master is triggered to enable the master and slave to convert the preempted channels simultaneously.

### 18.5.3 Alternate preempted trigger mode

**Alternate preempted trigger mode**

MSSEL bit in the ADC\_CCTRL register selects the alternate preempted trigger mode. If this mode is enabled, the preempted channels of the master are triggered continuously so that the master/slave ADCs convert the preempted channels alternately. Figure 18-16 shows an example of the alternate preempted trigger mode.

Figure 18-16 Alternate preempted trigger mode

**Combined regular simultaneous + alternate preempted trigger mode**

MSSEL bit in the ADC\_CCTRL register is used to select combined regular simultaneous + alternate preempted trigger mode. In this mode, trigger the regular group of the master to start regular simultaneous conversion of master/slave, or trigger the preempted group of the master continuously to allow the master/slave ADCs to convert the preempted group alternately.

If the regular conversion is interrupted by the preempted trigger, the regular conversion of all ADCs is stopped, and one of the ADCs starts the preempted conversion. At this point, the master will ignore the preempted trigger until the regular conversion is resumed.

#### 18.5.4 Regular shift mode

MSSEL bit in the ADC\_CCTRL register is used to select regular shift mode on regular group. After a master trigger occurs, the conversion interval between ADCs is based on the programmed shift length (through the ASISEL bit in the ADC\_CCTRL register), as shown in Figure 18-17.

In this mode, the sampling interval between ADCs is configured to be at least 2.5 ADCCLK cycles by hardware. Thus the ASISEL bit becomes invalid when it cannot meet such sampling interval.

Because of this feature, it is possible to put the same channel in the same ADC location without causing the overlapped sampling time.

The single slave mode can work with the transfer mode 1/2/3 (MSDMASEL), while the dual slave mode can work with all transfer modes. Figure 18-18 shows how to store data when the dual slave regular shift mode works with DMA mode 2.

*Note: The preempted trigger or slave regular trigger is not allowed in this mode.*

Figure 18-17 Regular shift mode



Figure 18-18 Regular shift mode and DMA mode 2



## 18.6 ADC registers

Table 18-5 lists ADC register map and their reset values.

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

Table 18-5 ADC register map and reset values

| Register    | Offset | Reset value |
|-------------|--------|-------------|
| ADC1_STS    | 0x000  | 0x0000 0000 |
| ADC1_CTRL1  | 0x004  | 0x0000 0000 |
| ADC1_CTRL2  | 0x008  | 0x0000 0000 |
| ADC1_SPT1   | 0x00C  | 0x0000 0000 |
| ADC1_SPT2   | 0x010  | 0x0000 0000 |
| ADC1_PCDTO1 | 0x014  | 0x0000 0000 |
| ADC1_PCDTO2 | 0x018  | 0x0000 0000 |
| ADC1_PCDTO3 | 0x01C  | 0x0000 0000 |
| ADC1_PCDTO4 | 0x020  | 0x0000 0000 |
| ADC1_VMHB   | 0x024  | 0x0000 FFFF |
| ADC1_VMLB   | 0x028  | 0x0000 0000 |
| ADC1_OSQ1   | 0x02C  | 0x0000 0000 |
| ADC1_OSQ2   | 0x030  | 0x0000 0000 |
| ADC1_OSQ3   | 0x034  | 0x0000 0000 |
| ADC1_PSQ    | 0x038  | 0x0000 0000 |
| ADC1_PDT1   | 0x03C  | 0x0000 0000 |
| ADC1_PDT2   | 0x040  | 0x0000 0000 |
| ADC1_PDT3   | 0x044  | 0x0000 0000 |
| ADC1_PDT4   | 0x048  | 0x0000 0000 |
| ADC1_ODT    | 0x04C  | 0x0000 0000 |
| ADC1_OVSP   | 0x080  | 0x0000 0000 |
| ADC1_CALVAL | 0x0B4  | 0x0000 0000 |

|             |       |             |
|-------------|-------|-------------|
| ADC2_STS    | 0x100 | 0x0000 0000 |
| ADC2_CTRL1  | 0x104 | 0x0000 0000 |
| ADC2_CTRL2  | 0x108 | 0x0000 0000 |
| ADC2_SPT1   | 0x10C | 0x0000 0000 |
| ADC2_SPT2   | 0x110 | 0x0000 0000 |
| ADC2_PCDTO1 | 0x114 | 0x0000 0000 |
| ADC2_PCDTO2 | 0x118 | 0x0000 0000 |
| ADC2_PCDTO3 | 0x11C | 0x0000 0000 |
| ADC2_PCDTO4 | 0x120 | 0x0000 0000 |
| ADC2_VMHB   | 0x124 | 0x0000 FFFF |
| ADC2_VMLB   | 0x128 | 0x0000 0000 |
| ADC2_OSQ1   | 0x12C | 0x0000 0000 |
| ADC2_OSQ2   | 0x130 | 0x0000 0000 |
| ADC2_OSQ3   | 0x134 | 0x0000 0000 |
| ADC2_PSQ    | 0x138 | 0x0000 0000 |
| ADC2_PDT1   | 0x13C | 0x0000 0000 |
| ADC2_PDT2   | 0x140 | 0x0000 0000 |
| ADC2_PDT3   | 0x144 | 0x0000 0000 |
| ADC2_PDT4   | 0x148 | 0x0000 0000 |
| ADC2_ODT    | 0x14C | 0x0000 0000 |
| ADC2_OVSP   | 0x180 | 0x0000 0000 |
| ADC2_CALVAL | 0x1B4 | 0x0000 0000 |
| ADC3_STS    | 0x200 | 0x0000 0000 |
| ADC3_CTRL1  | 0x204 | 0x0000 0000 |
| ADC3_CTRL2  | 0x208 | 0x0000 0000 |
| ADC3_SPT1   | 0x20C | 0x0000 0000 |
| ADC3_SPT2   | 0x210 | 0x0000 0000 |
| ADC3_PCDTO1 | 0x214 | 0x0000 0000 |
| ADC3_PCDTO2 | 0x218 | 0x0000 0000 |
| ADC3_PCDTO3 | 0x21C | 0x0000 0000 |
| ADC3_PCDTO4 | 0x220 | 0x0000 0000 |
| ADC3_VMHB   | 0x224 | 0x0000 FFFF |
| ADC3_VMLB   | 0x228 | 0x0000 0000 |
| ADC3_OSQ1   | 0x22C | 0x0000 0000 |
| ADC3_OSQ2   | 0x230 | 0x0000 0000 |
| ADC3_OSQ3   | 0x234 | 0x0000 0000 |
| ADC3_PSQ    | 0x238 | 0x0000 0000 |
| ADC3_PDT1   | 0x23C | 0x0000 0000 |
| ADC3_PDT2   | 0x240 | 0x0000 0000 |
| ADC3_PDT3   | 0x244 | 0x0000 0000 |
| ADC3_PDT4   | 0x248 | 0x0000 0000 |

|             |       |             |
|-------------|-------|-------------|
| ADC3_ODT    | 0x24C | 0x0000 0000 |
| ADC3_OVSP   | 0x280 | 0x0000 0000 |
| ADC3_CALVAL | 0x2B4 | 0x0000 0000 |
| ADC_CSTS    | 0x300 | 0x0000 0000 |
| ADC_CCTRL   | 0x304 | 0x0000 0000 |
| ADC_CODT    | 0x308 | 0x0000 0000 |

### 18.6.1 ADC status register (ADC\_STS)

Accessed by words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                            |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x00000000  | resd | Kept at its default value.                                                                                                                                                                                                                                             |
| Bit 6     | RDY      | 0x0         | rw0c | <p>ADC conversion ready flag<br/>This bit is read only. It is set by hardware when the ADC is powered.</p> <p>0: Not ready for ADC conversion<br/>1: Ready for ADC conversion</p>                                                                                      |
| Bit 5     | OCCO     | 0x0         | rw0c | <p>Ordinary channel conversion overflow flag<br/>This bit is set by hardware and cleared by software (writing 0).</p> <p>0: No overflow occurred<br/>1: Overflow occurred</p> <p>Overflow detection is applicable to the case of DMA transfer enable or EOCSFEN =1</p> |
| Bit 4     | OCCS     | 0x0         | rw0c | <p>Ordinary channel conversion start flag<br/>This bit is set by hardware and cleared by software (writing 0).</p> <p>0: No ordinary channel conversion started<br/>1: Ordinary channel conversion has started</p>                                                     |
| Bit 3     | PCCS     | 0x0         | rw0c | <p>Preempted channel conversion start flag<br/>This bit is set by hardware and cleared by software (writing 0).</p> <p>0: No preempted channel conversion started<br/>1: Preempted channel conversion has started</p>                                                  |
| Bit 2     | PCCE     | 0x0         | rw0c | <p>Preempted channel end of conversion flag<br/>This bit is set by hardware and cleared by software (writing 0).</p> <p>0: Conversion is not complete<br/>1: Conversion is complete</p>                                                                                |
| Bit 1     | OCCE     | 0x0         | rw0c | <p>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.</p> <p>0: Conversion is not complete<br/>1: Conversion is complete</p>                                                            |
| Bit 0     | VMOR     | 0x0         | rw0c | <p>Voltage monitoring out of range flag<br/>This bit is set by hardware and cleared by software (writing 0).</p> <p>0: Voltage is within the value programmed<br/>1: Voltage is outside the value programmed</p>                                                       |

## 18.6.2 ADC control register 1 (ADC\_CTRL1)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 27 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                             |
| Bit 26     | OCCOIE   | 0x0         | rw   | Ordinary channel conversion overflow interrupt enable<br>0: Ordinary channel conversion overflow interrupt disabled<br>1: Ordinary channel conversion overflow interrupt enabled                                                                                                                                       |
| Bit 25: 24 | CRSEL    | 0x0         | rw   | Conversion resolution select<br>00: 12-bit<br>01: 10-bit<br>10: 8-bit<br>11: 6-bit                                                                                                                                                                                                                                     |
| 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 its 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<br>1: Partitioned mode enabled on ordinary channels                                                               |
| Bit 10     | PCAUTOEN | 0x0         | rw   | Preempted group automatic conversion enable after ordinary group<br>0: Preempted group automatic conversion disabled<br>1: Preempted group automatic conversion enabled                                                                                                                                                |
| Bit 9      | VMSGEN   | 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, an OCCE 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 field is valid only when the VMSGEN 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, configuration is not allowed. |

### 18.6.3 ADC control register 2 (ADC\_CTRL2)

Accessed by words.

| Bit                  | Name     | Reset value | Type | Description                                                                                                                                                                                                                                    |
|----------------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 30: 26           | Reserved | 0x00        | resd | Kept at its default value                                                                                                                                                                                                                      |
| Bit 30               | 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 29: 28           | OCETE    | 0x0         | rw   | Ordinary channel external trigger edge select<br>00: Edge trigger forbidden<br>01: Rising edge<br>01: Falling edge<br>11: Any edge                                                                                                             |
| Bit 31<br>Bit 27: 24 | OCTESEL  | 0x0         | rw   | Ordinary channel conversion trigger event select<br>Note:<br>Refer to section <a href="#">18.4.1.1</a> for details on bits.                                                                                                                    |
| 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 21: 20           | PCETE    | 0x0         | rw   | Preempted channel external trigger edge select<br>00: Edge trigger forbidden<br>01: Rising edge<br>01: Falling edge<br>11: Any edge                                                                                                            |
| Bit 23<br>Bit 19: 16 | PCTESEL  | 0x0         | rw   | Preempted channel conversion trigger event select<br>Note:<br>Refer to section <a href="#">18.4.1.1</a> for details on bits.                                                                                                                   |
| Bit 15: 12           | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                     |

|          |           |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 11   | DTALIGN   | 0x0 | rw   | Data alignment<br>0: Right alignment<br>1: Left alignment                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 10   | EOCSFEN   | 0x0 | rw   | Each ordinary channel conversion OCCE flag enable)<br>0: Disabled<br>1: Enabled<br>Note: Overflow detection is enabled automatically when this bit is set.                                                                                                                                                                                                                                                                                                      |
| Bit 9    | OCDRCEN   | 0x0 | rw   | Ordinary channel DMA request continue enable for independent mode)<br>0: Disabled (After the completion of the programmed number of DMA transfers, no DMA request generated at the end of ordinary conversion)<br>1: Enabled (Don't care about the programmed number of DMA transfers, Each ordinary channel sends DMA request at the end of ordinary conversion)<br>Note:<br>This bit is set only in non-master/slave mode with OCDMAEN = 1.                   |
| Bit 8    | OCDMAEN   | 0x0 | rw   | DMA transfer enable of ordinary channels<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 7: 5 | Reserved  | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 4    | ADABRT    | 0x0 | rw   | ADC conversion abort<br>0: ADC conversion is not aborted<br>1: ADC conversion is aborted<br>Note: This bit is cleared by hardware after ADC conversion is aborted. After this bit is cleared, re-triggering ADC conversion is allowed. If the ADABRT is set, it is necessary to wait until it is cleared before starting related ADC operations.                                                                                                                |
| 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 initializations 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 conversion is done each time when a trigger event arrives; when SQEN=1, a group of repetition is done each timer when a trigger event arrives.<br>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. |

---

|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | A/D converter enable<br>0: A/D converter disabled (ADC goes to power-down mode)<br>1: A/D converter enabled<br>Note:<br>When this bit is in OFF state, write an ON command can wake up The ADC from power-down mode.<br>When this bit in ON state, write another ON command can start a regular group conversion.<br>The application should pay attention to the fact that there is a delay of t <sub>STAB</sub> between power on and start of conversion. |
| Bit 0 | ADCEN | 0x0 | rw |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

---

## 18.6.4 ADC sampling time register 1 (ADC\_SPT1)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                               |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 27 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                |
| Bit 26: 24 | CSPT18   | 0x0         | rw   | Sample time selection of channel ADC_IN18<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles                   |
| Bit 23: 21 | CSPT17   | 0x0         | rw   | Sample time selection of channel ADC_IN17<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles 111: 239.5 cycles |
| Bit 20: 18 | CSPT16   | 0x0         | rw   | Sample time selection of channel ADC_IN16<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles                   |
| Bit 17: 15 | CSPT15   | 0x0         | rw   | Sample time selection of channel ADC_IN15<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles                   |

---

|            |        |     |    |                                                                                                                                                                                                           |
|------------|--------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        |     |    | Sample time selection of channel ADC_IN14<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles   |
| Bit 14: 12 | CSPT14 | 0x0 | rw | Sample time selection of channel ADC_IN13<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 11: 9  | CSPT13 | 0x0 | rw | Sample time selection of channel ADC_IN12<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 8: 6   | CSPT12 | 0x0 | rw | Sample time selection of channel ADC_IN11<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 5: 3   | CSPT11 | 0x0 | rw | Sample time selection of channel ADC_IN10<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 2: 0   | CSPT10 | 0x0 | rw | Sample time selection of channel ADC_IN9<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles  |

## 18.6.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 its default value                                                                                                                                                                              |
| Bit 29: 27 | CSPT9    | 0x0         | rw   | Sample time selection of channel ADC_IN9<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 26: 24 | CSPT8    | 0x0         | rw   | Sample time selection of channel ADC_IN8<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 23: 21 | CSPT7    | 0x0         | rw   | Sample time selection of channel ADC_IN7<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 20: 18 | CSPT6    | 0x0         | rw   | Sample time selection of channel ADC_IN6<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 17: 15 | CSPT5    | 0x0         | rw   | Sample time selection of channel ADC_IN5<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |

|            |       |     |    |                                                                                                                                                                                                          |
|------------|-------|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |       |     |    | Sample time selection of channel ADC_IN4<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles   |
| Bit 14: 12 | CSPT4 | 0x0 | rw | Sample time selection of channel ADC_IN3<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles   |
| Bit 11: 9  | CSPT3 | 0x0 | rw | Sample time selection of channel ADC_IN2<br>000: Reserved<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles   |
| Bit 8: 6   | CSPT2 | 0x0 | rw | Sample time selection of channel ADC_IN1<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 5: 3   | CSPT1 | 0x0 | rw | Sample time selection of channel ADC_IN0<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |
| Bit 2: 0   | CSPT0 | 0x0 | rw | Sample time selection of channel ADC_IN0<br>000: 2.5 cycles<br>001: 6.5 cycles<br>010: 12.5 cycles<br>011: 24.5 cycles<br>100: 47.5 cycles<br>101: 92.5 cycles<br>110: 247.5 cycles<br>111: 640.5 cycles |

## 18.6.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 its 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 |

## 18.6.7 ADC voltage monitor high threshold register (ADC\_VWHB)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                      |
|------------|----------|-------------|------|----------------------------------|
| Bit 31: 16 | Reserved | 0x00000     | resd | Kept at its default value        |
| Bit 15: 0  | VMHB     | 0xFFFF      | rw   | Voltage monitoring high boundary |

## 18.6.8 ADC voltage monitor low threshold register (ADC\_VWLB)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                     |
|------------|----------|-------------|------|---------------------------------|
| Bit 31: 16 | Reserved | 0x00000     | resd | Kept at its default value       |
| Bit 15: 0  | VMLB     | 0xFFFF      | rw   | Voltage monitoring low boundary |

## 18.6.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 its 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                                                                                                  |
|            |          |             |      | Number of 13th conversion in ordinary sequence                                                                                                  |
| Bit 4: 0   | OSN13    | 0x00        | rw   | Note: The number can be from 0 to 17. For example, if the number is set to 3, it means that the 13 <sup>th</sup> conversion is ADC_IN3 channel. |

## 18.6.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 its 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                                                                                                  |
|          |      |      |    | Number of 7th conversion in ordinary sequence                                                                                                  |
| Bit 4: 0 | OSN7 | 0x00 | rw | Note: The number can be from 0 to 17. For example, if the number is set to 8, it means that the 7 <sup>th</sup> conversion is ADC_IN8 channel. |

### 18.6.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 its 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                                                                                       |
|            |          |             |      | Number of 1st conversion in ordinary sequence                                                                                       |
| Bit 4: 0   | OSN1     | 0x00        | rw   | Note: The number can be from 0 to 17. For example, if the number is set to 8, it means that the 1st conversion is ADC_IN17 channel. |

### 18.6.12 ADC preempted sequence register (ADC\_PSQ)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                             |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at its 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                                                                                                                                                                          |
|            |          |             |      | Number of 1st conversion in preempted sequence<br>Note: The number can be from 0 to 17. For example, if the number is set to 3, it refers to the ADC_IN3 channel.                                                       |
| Bit 4: 0   | PSN1     | 0x00        | rw   | 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. |

### 18.6.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 its default value              |
| Bit 15: 0  | PDTx     | 0x0000      | rw   | Conversion data from preempted channel |

### 18.6.14 ADC ordinary data register (ADC\_ODT)

Accessed by words.

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                        |
|------------|---------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | ADC2ODT | 0x0000      | ro   | ADC2 conversion data of ordinary channel<br>Note:<br>These bits are reserved in ADC2 and ADC3.<br>In ADC1, these bits are valid only in master/slave mode, and they contain the conversion result from the ADC2 ordinary channels. |
| Bit 15: 0  | ODT     | 0x0000      | ro   | Conversion data of ordinary channel                                                                                                                                                                                                |

### 18.6.15 ADC oversampling register (ADC\_OVSP)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 11 | Reserved | 0x0000      | resd | Kept at its 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: 1 bit<br>0010: 2 bits<br>0011: 3 bits<br>0100: 4 bits<br>0101: 5 bits<br>0110: 6 bits<br>0111: 7 bits<br>1000: 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 |
|-------|-------|-----|----|-------------------------------------------------------------------------------------------------------|

---

### 18.6.16 ADC calibration value register (ADC\_CALVAL)

Accessed by words.

| Bit       | Name     | Reset value | Type | Description                |
|-----------|----------|-------------|------|----------------------------|
| Bit 31: 7 | Reserved | 0x0000      | resd | Kept at its default value. |
| Bit 6: 0  | CALVAL   | 0x0         | rw   | A/D Calibration value      |

---

### 18.6.17 ADC common status register (ADC\_CSTS)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                             |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                              |
| Bit 22     | RDY3     | 0x0         | ro   | ADC3 conversion ready flag<br>This bit is the mapping bit of the RDY bit in the ADC3_STS register.                      |
| Bit 21     | OCCO3    | 0x0         | ro   | ADC3 ordinary channel conversion overflow flag<br>This bit is the mapping bit of the OCCO bit in the ADC3_STS register. |
| Bit 20     | OCCS3    | 0x0         | ro   | ADC3 ordinary channel conversion start flag<br>This bit is the mapping bit of the OCCS bit in the ADC3_STS register.    |
| Bit 19     | PCCS3    | 0x0         | ro   | ADC3 Preempted channel conversion start flag<br>This bit is the mapping bit of the PCCS bit in the ADC3_STS register.   |
| Bit 18     | PCCE3    | 0x0         | ro   | ADC3 preempted channels conversion end flag<br>This bit is the mapping bit of the PCCE bit in the ADC3_STS register.    |
| Bit 17     | OCCE3    | 0x0         | ro   | ADC3 ordinary channels conversion end flag<br>This bit is the mapping bit of the OCCE bit in the ADC3_STS register.     |
| Bit 16     | VMOR3    | 0x0         | ro   | ADC3 voltage monitoring out of range flag<br>This bit is the mapping bit of the VMOR bit in the ADC3_STS register.      |
| Bit 15     | Reserved | 0x0         | resd | Kept at its default value.                                                                                              |
| Bit 14     | RDY2     | 0x0         | ro   | ADC2 conversion ready flag<br>This bit is the mapping bit of the RDY bit in the ADC2_STS register.                      |
| Bit 13     | OCCO2    | 0x0         | ro   | ADC2 ordinary channel conversion overflow flag<br>This bit is the mapping bit of the OCCO bit in the ADC2_STS register. |
| Bit 12     | OCCS2    | 0x0         | ro   | ADC2 ordinary channel conversion start flag<br>This bit is the mapping bit of the OCCS bit in the ADC2_STS register.    |
| Bit 11     | PCCS2    | 0x0         | ro   | ADC2 preempted channel conversion start flag<br>This bit is the mapping bit of the PCCS bit in the ADC2_STS register.   |

---

|        |          |     |      |                                                                                                                         |
|--------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------|
| Bit 10 | PCCE2    | 0x0 | ro   | ADC2 Preempted channels conversion end flag<br>This bit is the mapping bit of the PCCE bit in the ADC2_STS register.    |
| Bit 9  | OCCE2    | 0x0 | ro   | ADC2 ordinary channels conversion end flag<br>This bit is the mapping bit of the OCCE bit in the ADC2_STS register.     |
| Bit 8  | VMOR2    | 0x0 | ro   | ADC2 voltage monitoring out of range flag<br>This bit is the mapping bit of the VMOR bit in the ADC2_STS register.      |
| Bit 7  | Reserved | 0x0 | resd | Kept at its default value.                                                                                              |
| Bit 6  | RDY1     | 0x0 | ro   | ADC1 conversion ready flag<br>This bit is the mapping bit of the RDY bit in the ADC1_STS register.                      |
| Bit 5  | OCCO1    | 0x0 | ro   | ADC1 ordinary channel conversion overflow flag<br>This bit is the mapping bit of the OCCO bit in the ADC1_STS register. |
| Bit 4  | OCCS1    | 0x0 | ro   | ADC1 ordinary channel conversion start flag<br>This bit is the mapping bit of the OCCS bit in the ADC1_STS register.    |
| Bit 3  | PCCS1    | 0x0 | ro   | ADC1 Preempted channel conversion start flag<br>This bit is the mapping bit of the PCCS bit in the ADC1_STS register.   |
| Bit 2  | PCCE1    | 0x0 | ro   | ADC1 preempted channels conversion end flag<br>This bit is the mapping bit of the PCCE bit in the ADC1_STS register.    |
| Bit 1  | OCCE1    | 0x0 | ro   | ADC1 ordinary channels conversion end flag<br>This bit is the mapping bit of the OCCE bit in the ADC1_STS register.     |
| Bit 0  | VMOR1    | 0x0 | ro   | ADC1 voltage monitoring out of range flag<br>This bit is the mapping bit of the VMOR bit in the ADC1_STS register.      |

### 18.6.18 ADC common control register (ADC\_CCTRL)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                            |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x0000      | resd | Kept at its default value.                                                             |
| Bit 23     | ITSRVEN  | 0x0         | rw   | Internal temperature sensor and V <sub>INTRV</sub> enable<br>0: Disabled<br>1: Enabled |
| Bit 22     | VBATEN   | 0x0         | rw   | V <sub>BAT</sub> enable<br>0: Disabled<br>1: Enabled                                   |
| Bit 21: 20 | Reserved | 0x0         | resd | Kept at its default value.                                                             |

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |     |      | ADC division<br>0000: HCLK/2<br>0001: HCLK/3<br>...<br>1111: HCLK/17                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 19: 16 | ADCDIV   | 0x0 | rw   | Note:<br>The clock divided by this field are used by all ADCs.<br>The maximum value of the ADCCLK is 80 MHz. After this division, the ADCCLK cannot be higher than PCLK2.                                                                                                                                                                                                                                                                                                           |
| Bit 28     | MSDMASEL | 0x0 | rw   | Ordinary channel DMA transfer mode select in master/slave mode<br>MSDMASEL[2] is the 28 <sup>th</sup> bit in the ADC_CCTRL register.<br>MSDMASEL[2: 0] is defined as follows:<br>000: No DMA transfer<br>001: DMA mode 1<br>010: DMA mode 2<br>011: DMA mode 3<br>100: DMA mode 4<br>101: DMA mode 5<br>110~111: Unused. Do not configure.<br>Note:<br>This field is applicable in master/slave mode. Refer to Section 18.5.1 for details on DMA mode x.                            |
| Bit 15: 14 |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 13     | MSDRCEN  | 0x0 | rw   | Ordinary channel DMA request continuation enable in master/slave mode<br>0: Disabled (After the completion of the programmed number of DMA transfers, no DMA request generated at the end of ordinary conversion)<br>1: Enabled (Don't care about the programmed number of DMA transfers, Each ordinary channel sends DMA request at the end of ordinary conversion)<br>Note: This bit is applicable in master/slave mode and when DMA mode x is selected through the MSDMASEL bit. |
| Bit 12     | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 11: 8  | ASISEL   | 0x0 | rw   | Adjacent ADC sampling interval select in ordinary shift mode<br>0000: 5 * TADCCLK<br>0001: 6 * TADCCLK<br>0010: 7 * TADCCLK<br>...<br>1111: 20 * TADCCLK<br>Note:<br>This field is used to configure the conversion interval between adjacent ADCs in ordinary shift mode. Refer to Section 18.5.4 for details.                                                                                                                                                                     |
| Bit 7: 5   | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Bit 4: 0 MSSEL

0x00

rw

Combined master/slave mode select  
00000: Non-combined mode  
00001: Combined ordinary simultaneous+preempted simultaneous modes (single slave)  
00010: Combined ordinary simultaneous+alternate preempted trigger modes (single slave)  
00011~00100: Unused. Do not configure  
00101: Preempted simultaneous mode (single slave)  
00110: Ordinary simultaneous mode (single slave)  
00111: Ordinary shift mode (single slave)  
01000: Unused. Do not configure  
01001: Alternate preempted trigger mode (single slave)  
01010~10000: Unused. Do not configure  
10001: Combined ordinary simultaneous+preempted simultaneous modes (dual slave)  
10010: Combined ordinary simultaneous+alternate preempted trigger modes (dual slave)  
10011~10100: Unused. Do not configure  
10101: Preempted simultaneous mode (dual slave)  
10110: Ordinary simultaneous mode (dual slave)  
10111: Ordinary shift mode (dual slave)  
11000: Unused. Do not configure  
11001: Alternate preempted trigger mode (dual slave)  
11010~11111: Unused. Do not configure  
Note: In combined master/slave mode, the change of configuration will cause loss of synchronization between master and slave. Thus it is recommended to disable combined master/slave mode before changing.

## 18.6.19 ADC common data register (ADC\_CODT)

Accessed by words.

| Bit        | Name  | Reset value | Type | Description                                                                                                                                                                                             |
|------------|-------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | CODTH | 0x0000      | rw   | <p>Ordinary conversion high halfword data in master slave mode</p> <p>Note: The meanings of data in this field vary from DMA mode to DMA mode. Refer to Section <a href="#">18.5.1</a> for details.</p> |
| Bit 15: 0  | CODTL | 0x0000      | rw   | <p>Ordinary conversion low halfword data in master slave mode</p> <p>Note: The meanings of data in this field vary from DMA mode to DMA mode. Refer to Section <a href="#">18.5.1</a> for details.</p>  |

# 19 Digital-to-analog converter (DAC)

## 19.1 DAC introduction

The DAC uses a 12-bit digital input to generate an analog output between 0 and reference voltage. The digital part of the DAC can be configured in 8-bit or 12-bit mode and can be used in conjunction with the DMA. It supports left or right alignment in a single /dual DAC modes. It has two output channels, DAC1 and DAC2, with its own converter each. Each DAC1/DAC2 can be converted independently or simultaneously in dual DAC mode. The input reference voltage  $V_{REF+}$  makes conversion more accuracy.

Figure 19-1 DAC1/DAC2 block diagram



## 19.2 DAC main features

- A single/dual DAC 8-bit or 12-bit digital input
- Left or right data alignment
- Noise-wave/Triangular-wave generation
- Dual DAC or single DAC1/DAC2 independent conversions
- DMA mode for DAC1/DAC2
- Software or external triggers for conversion
- Input reference voltage  $V_{REF+}$

## 19.3 Design tips

The following information can be used as DAC design reference:

### ● Analog module configuration

The analog part of the DAC1/DAC2 can be enabled by setting the ENx bit in the DAC\_CTRL register, but its digital part is not subject to this bit. The DAC integrates two output gains that can be used to reduce the output impedance, and to drive external loads directly without the need of an external operational amplifier. The DAC1/DAC2 output gain can be enabled and disabled through the DxOBDIS bit in the DAC\_CTRL register.

### ● DMA capability

The DAC1/DAC2 both have a DMA capability that can be enabled by setting the DxDMAEN bit in the DAC\_CTRL register. One DMA request is generated when a trigger signal is active while the DxTRGEN bit is set. The DAC DMA request is not added up, meaning the new DAM request will be ignored and no error is reported.

In dual DAC mode, the application can handle two channels (DAC1/DAC2) by using only one DMA request and a DMA channel.

- DMA underflow

When the DAC DMA request is enabled, an overflow occurs if a second external trigger arrives before the acknowledgement for the first external trigger is received. In this case, no new external trigger is handled, or no new DMA request is issued, and the DxDMAUDRF bit in the DAC\_SR register is set, reporting the error condition. An interrupt is generated if its corresponding DxDMAUDRIEN bit in the DAC\_CTRL register is set.

The software clears the DxDMAUDRF bit by writing 1. The DxDMAEN bit should be cleared in the DAC\_CTRL register before re-starting a DMA transfer and re-initializing DMA and DAC.

- Input/output configuration

The digital inputs are linearly converted to analog voltage outputs by the DAC, and it is between 0 and  $V_{REF+}$ . The analog DAC module is supplied by VDDA. The positive analog reference voltage input falls between 2.0 V and VDDA. To avoid parasitic interruption and excessive consumption, the PA4 or PA5 should be configured to analog input.

$$\text{DAC output} = V_{REF+} \times (\text{DxDOT}[11:0]/4095)$$

## 19.4 Functional overview

### 19.4.1 Trigger events

If the DxTRGEN bit in the DAC\_CTRL register is set, the DAC conversion can then be triggered by an external event (timer counter, external interrupt line) or by software. The DxTRGSEL[2:0] is used to select trigger sources.

Table 19-1 Trigger source selection

| Source      | DxTRGSEL [2:0] | Description      |
|-------------|----------------|------------------|
| TMR6_TRGOUT | 000            | On-chip signals  |
| TMR8_TRGOUT | 001            |                  |
| TMR7_TRGOUT | 010            |                  |
| TMR5_TRGOUT | 011            |                  |
| TMR2_TRGOUT | 100            |                  |
| TMR4_TRGOUT | 101            |                  |
| EXINT_9     | 110            | External signals |
| DxSWTRG     | 111            | Software trigger |

When the DxTRGEN bit is set, the data stored into the HDRx register is transferred into the DAC\_DxDOT register each time a DAC detects an active trigger event,. If the software trigger is selected, the DxSWTRG flag is cleared by hardware after writing 1. The DAC output becomes active after a period of time once the data is loaded into the DAC\_DxDOT register.

When the DxTRGEN bit is cleared, each data written to the data register is immediately transferred into the DAC\_DxDOT register without the need of a trigger event.

### 19.4.2 Noise/Triangular-wave generation

The DAC can output a variable-amplitude pseudo noise and a triangular wave, which is done by the LENinear Feedback Shift Register and triangle wave generator respectively. The DAC variable-amplitude pseudo noise generation is selected by setting DxNM[1:0]=01 in the LFSR, while the DAC triangular-wave generation is selected by setting the DxNM[1:0]=1x.

#### LFSR logic

The preloaded value in the LFSR is 0xAAA. This register is updated after each trigger event based on a specific calculation algorithm.

Figure 19-2 LFSR register calculation algorithm



The DxNBSEL [3: 0] bit in the DAC\_CTRL register is set to mark partially or totally the LFSR data. The resulting value is then added up to the DHRx value without overflow and this value is loaded into the DAC\_DxODT register. It is possible to disable LFSR function and reset LFSR wave generation algorithm by setting DxNM[1: 0]=00.

### Triangular wave logic

The DAC triangular-wave generation is selected by setting DxNM[1: 0]=1x. The amplitude is configured through the DxNBSEL [3: 0] bit in the DAC\_CTRL register. An internal triangular-wave counter is incremented at each trigger event. Once the maximum amplitude programmed in the DxNBSEL [3: 0] is reached, the value of this counter is decremented down to 0, then incremented again, and so on.

Meanwhile, the value of this counter is then added up to the DHRx register without overflow and the resulting value is loaded into the DAC\_DxODT register. It is possible to disable/reset the triangular-wave generation by setting DxNM[1: 0]=00.

Figure 19-3 Triangular-wave generation



### 19.4.3 DAC data alignment

The DAC supports a single DAC and dual DA mode. The data format is dependent on the selected configuration mode.

#### Single DAC data format:

8-bit right alignment: load data into the DAC\_DxDTH8R [7:0]

12-bit left alignment: load data into the DAC\_DxDTH12L [15: 4]

12-bit right alignment: load data in the DAC\_DxDTH12R [11: 0]

#### Dual DAC data format:

8-bit right alignment: load data into the DAC\_DDTH8R [7: 0] and DAC\_DDTH8R [15: 8]

12-bit left alignment: load data into the DAC\_DDTH12L [15: 4] and DAC\_DDTH12L [31: 20]

12-bit right alignment: load data into the DAC\_DDTH12R [11: 0] and DAC\_DDTH12R [27:16]

The loaded 8-bit data corresponds to the DHRx[11:4] and the loaded 12-bit data corresponds to the DHRx[11: 0]

## 19.5 DAC registers

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

Table 19-2 DAC register map and reset values

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| DAC_CTRL     | 000h   | 0x0000 0000 |
| DAC_SWTRG    | 004h   | 0x0000 0000 |
| DAC_D1DTH12R | 008h   | 0x0000 0000 |
| DAC_D1DTH12L | 00Ch   | 0x0000 0000 |
| DAC_D1DTH8R  | 010h   | 0x0000 0000 |
| DAC_D2DTH12R | 014h   | 0x0000 0000 |
| DAC_D2DTH12L | 018h   | 0x0000 0000 |
| DAC_D2DTH8R  | 01Ch   | 0x0000 0000 |
| DAC_DDTH12R  | 020h   | 0x0000 0000 |
| DAC_DDTH12L  | 024h   | 0x0000 0000 |
| DAC_DDTH8R   | 028h   | 0x0000 0000 |
| DAC_D1ODT    | 02Ch   | 0x0000 0000 |
| DAC_D2ODT    | 030h   | 0x0000 0000 |
| DAC_STS      | 034h   | 0x0000 0000 |

### 19.5.1 DAC control register (DAC\_CTRL)

| Bit        | Name        | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved    | 0x0         | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 29     | D2DMAUDRIEN | 0x0         | rw   | DAC2 DMA transfer underrun interrupt enable<br>This bit is set and cleared by software.<br>0: DAC2 DMA transfer underrun interrupt disabled<br>1: DAC2 DMA transfer underrun interrupt enabled                                                                                                                                                                                                                                                                                                                                                    |
| Bit 28     | D2DMAEN     | 0x0         | rw   | DAC2 DMA transfer enable<br>This bit is set and cleared by software.<br>0: DAC2 DMA mode disabled<br>1: DAC2 DMA mode enabled                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 27: 24 | D2NBSEL     | 0x0         | rw   | DAC2 noise bit select<br>These bits are used to select the mark bit in noise generation mode or amplitude in triangular-wave generation mode.<br>0000: Unmask LSFR bit0 /Triangle amplitude is equal to 1<br>0001: Unmask LSFR bit[1: 0] /Triangle amplitude is equal to 3<br>0010: Unmask LSFR bit[2: 0] /Triangle amplitude is equal to 7<br>0011: Unmask LSFR bit[3: 0] /Triangle amplitude is equal to 15<br>0100: Unmask LSFR bit[4: 0] /Triangle amplitude is equal to 31<br>0101: Unmask LSFR bit[5: 0] /Triangle amplitude is equal to 63 |

|            |             |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |     |      | 0110: Unmask LSFR bit[6: 0] /Triangle amplitude is equal to 127<br>0111: Unmask LSFR bit[7: 0] /Triangle amplitude is equal to 255<br>1000: Unmask LSFR bit[8: 0] /Triangle amplitude is equal to 511<br>1001: Unmask LSFR bit[9: 0] /Triangle amplitude is equal to 1023<br>1010: Unmask LSFR bit[10:0] /Triangle amplitude is equal to 2047<br>≥1011: Unmask LSFR bit[11: 0] /Triangle amplitude is equal to 4095                                                                                                                                                                     |
| Bit 23: 22 | D2NM        | 0x0 | rw   | DAC2 noise mode<br>00: Wave generation disabled<br>01: Noise wave generation enabled<br>1x: Triangular wave generation enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 21: 19 | D2TRGSEL    | 0x0 | rw   | DAC2 trigger select<br>000: TMR6 TRGOUT event<br>001: TMR8 TRGOUT event<br>010: TMR7 TRGOUT event<br>011: TMR5 TRGOUT event<br>100: TMR2 TRGOUT event<br>101: TMR4 TRGOUT event<br>110: External interrupt line 9<br>111: Software trigger<br><u>Note: These bits can be valid only when D2TRGEN = 1.</u>                                                                                                                                                                                                                                                                               |
| Bit 18     | D2TRGEN     | 0x0 | rw   | DAC2 trigger enable<br>0: DAC2 trigger disabled<br>1: DAC2 trigger enabled<br><u>Note:</u><br>When the DAC2 trigger is disabled, the data written into the DAC_D2DTHx register is transferred into the DAC_D2ODT register after one APB1 clock cycle.<br>When the DAC2 trigger is enabled, the data written into the DAC_D2DTHx register is transferred into the DAC_D2ODT register after three APB1 clock cycles.<br>If the software trigger is selected, it takes one APB1 clock cycle to have the data written into the DAC_D2DTHx register transferred into the DAC_D2ODT register. |
| Bit 17     | D2OBDIS     | 0x0 | rw   | DAC2 output buffer disable<br>0: DAC2 output buffer enabled<br>1: DAC2 output buffer disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 16     | D2EN        | 0x0 | rw   | DAC2 enable<br>0: DAC2 disabled<br>1: DAC2 enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 15: 14 | Reserved    | 0x0 | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 13     | D1DMAUDRIEN | 0x0 | rw   | DAC1 DMA transfer underrun interrupt enable<br>This bit is set and cleared by software.<br>0: DAC1 DMA transfer underrun interrupt disabled<br>1: DAC1 DMA transfer underrun interrupt enabled                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 12     | D1DMAEN     | 0x0 | rw   | DAC1 DMA transfer enable<br>0: DAC1 DMA transfer disabled<br>1: DAC1 DMA transfer enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 11: 8  | D1NBSEL     | 0x0 | rw   | DAC1 noise bit select<br>These bits are used to select the mark bit in noise generation mode or amplitude in triangular-wave generation mode.<br>0000: Unmask LSFR bit0/Triangle amplitude is equal to 1<br>0001: Unmask LSFR bit[1:0]/Triangle amplitude is equal to 3<br>0010: Unmask LSFR bit[2: 0]/Triangle amplitude is equal to 7<br>0011: Unmask LSFR bit[3: 0]/Triangle amplitude is equal to 15                                                                                                                                                                                |

|          |          |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|----------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |    | 0100: Unmask LSFR bit[4: 0]/Triangle amplitude is equal to 31<br>0101: Unmask LSFR bit[5: 0]/Triangle amplitude is equal to 63<br>0110: Unmask LSFR bit[6: 0]/Triangle amplitude is equal to 127<br>0111: Unmask LSFR bit[7: 0]/Triangle amplitude is equal to 255<br>1000: Unmask LSFR bit[8: 0]/Triangle amplitude is equal to 511<br>1001: Unmask LSFR bit[9: 0]/Triangle amplitude is equal to 1023<br>1010: Unmask LSFR bit[10: 0]/Triangle amplitude is equal to 2047<br>≥1011: Unmask LSFR bit[11:0]/Triangle amplitude is equal to 4095                                     |
| Bit 7: 6 | D1NM     | 0x0 | rw | DAC1 noise mode<br>00: Wave generation disabled<br>01: Noise wave generation enabled<br>1x: Triangular wave generation enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 5: 3 | D1TRGSEL | 0x0 | rw | DAC1 trigger select<br>000: TMR6 TRGOUT event<br>001: TMR8 TRGOUT event<br>010: TMR7 TRGOUT event<br>011: TMR5 TRGOUT event<br>100: TMR2 TRGOUT event<br>101: TMR4 TRGOUT event<br>110: External interrupt line 9<br>111: Software trigger<br><br>Note: These bits can be valid only when D1TRGEN = 1.                                                                                                                                                                                                                                                                              |
| Bit 2    | D1TRGEN  | 0x0 | rw | DAC1 trigger enable<br>0: DAC1 trigger disabled<br>1: DAC1 trigger enabled<br><br>Note:<br>When the DAC1 trigger is disabled, the data written into the DAC_D1DTHx register is transferred into the DAC_D1ODT register after one APB1 clock cycle.<br>When the DAC1 trigger is enabled, the data written into the DAC_D1DTHx register is transferred into the DAC_D1ODT register after three APB1 clock cycles<br>If the software trigger is selected, it takes one APB1 clock cycle to have the data written into the DAC_D1DTHx register transferred into the DAC_D1ODT register. |
| Bit 1    | D1OBDIS  | 0x0 | rw | DAC1 output buffer disable<br>0: DAC1 output buffer enabled<br>1: DAC1 output buffer disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 0    | D1EN     | 0x0 | rw | DAC1 enable<br>0: DAC1 disabled<br>1: DAC1 enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## 19.5.2 DAC software trigger register (DAC\_SWTRG)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                      |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 2 | Reserved | 0x0000 0000 | resd | Kept at its default value                                                                                                                                                                                                                        |
| Bit 1     | D2SWTRG  | 0x0         | rw   | <p>DAC2 software trigger<br/>0: DAC2 software trigger disabled<br/>1: DAC2 software trigger enabled</p> <p>Note: This bit is cleared by hardware (one APB1 clock cycle later) once the DAC_D2DTH data is loaded into the DAC_D2ODT register.</p> |
| Bit 0     | D1SWTRG  | 0x0         | rw   | <p>DAC1 software trigger<br/>0: DAC1 software trigger disabled<br/>1: DAC1 software trigger enabled</p> <p>Note: This bit is cleared by hardware (one APB1 clock cycle later) once the DAC_D1DTH data is loaded into the DAC_D1ODT register.</p> |

## 19.5.3 DAC1 12-bit right-aligned data holding register (DAC\_D1DTH12R)

| Bit        | Name     | Reset value | Type | Description                    |
|------------|----------|-------------|------|--------------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at its default value      |
| Bit 11: 0  | D1DT12R  | 0x000       | rw   | DAC1 12-bit right-aligned data |

## 19.5.4 DAC1 12-bit left-aligned data holding register (DAC\_D1DTH12L)

| Bit        | Name     | Reset value | Type | Description                   |
|------------|----------|-------------|------|-------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value     |
| Bit 15: 4  | D1DT12L  | 0x000       | rw   | DAC1 12-bit left-aligned data |
| Bit 3: 0   | Reserved | 0x0         | resd | Kept at its default value     |

## 19.5.5 DAC1 8-bit right-aligned data holding register (DAC\_D1DTH8R)

| Bit       | Name     | Reset value | Type | Description                   |
|-----------|----------|-------------|------|-------------------------------|
| Bit 31: 8 | Reserved | 0x0000000   | resd | Kept at its default value     |
| Bit 7: 0  | D1DT8R   | 0x00        | rw   | DAC1 8-bit right-aligned data |

## 19.5.6 DAC2 12-bit right-aligned data holding register (DAC\_D2DTH12R)

| Bit        | Name     | Reset value | Type | Description                    |
|------------|----------|-------------|------|--------------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at its default value      |
| Bit 11: 0  | D2DT12R  | 0x000       | rw   | DAC2 12-bit right-aligned data |

## 19.5.7 DAC2 12-bit left-aligned data holding register (DAC\_D2DTH12L)

| Bit        | Name     | Reset value | Type | Description                   |
|------------|----------|-------------|------|-------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value     |
| Bit 15: 4  | D2DT12L  | 0x000       | rw   | DAC2 12-bit left-aligned data |
| Bit 3: 0   | Reserved | 0x0         | resd | Kept at its default value     |

### 19.5.8 DAC2 8-bit right-aligned data holding register (DAC\_D2DTH8R)

| Bit       | Name     | Reset value | Type | Description                   |
|-----------|----------|-------------|------|-------------------------------|
| Bit 31: 8 | Reserved | 0x000000    | resd | Kept at its default value     |
| Bit 7: 0  | D2DT8R   | 0x00        | rw   | DAC2 8-bit right-aligned data |

### 19.5.9 Dual DAC 12-bit right-aligned data holding register (DAC\_DDTH12R)

| Bit        | Name     | Reset value | Type | Description                    |
|------------|----------|-------------|------|--------------------------------|
| Bit 31: 28 | Reserved | 0x0         | resd | Kept at its default value      |
| Bit 27: 16 | DD2DT12R | 0x000       | rw   | DAC2 12-bit right-aligned data |
| Bit 15: 12 | Reserved | 0x0         | resd | Kept at its default value      |
| Bit 11: 0  | DD1DT12R | 0x000       | rw   | DAC1 12-bit right-aligned data |

### 19.5.10 Dual DAC 12-bit left-aligned data holding register (DAC\_DDTH12L)

| Bit        | Name     | Reset value | Type | Description                   |
|------------|----------|-------------|------|-------------------------------|
| Bit 31: 20 | DD2DT12L | 0x000       | rw   | DAC2 12-bit left-aligned data |
| Bit 19: 16 | Reserved | 0x0         | resd | Kept at its default value     |
| Bit 15: 4  | DD1DT12L | 0x000       | rw   | DAC1 12-bit left-aligned data |
| Bit 3: 0   | Reserved | 0x0         | resd | Kept at its default value     |

### 19.5.11 Dual DAC 8-bit right-aligned data holding register (DAC\_DDTH8R)

| Bit        | Name     | Reset value | Type | Description                   |
|------------|----------|-------------|------|-------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value     |
| Bit 15: 8  | DD2DT8R  | 0x00        | rw   | DAC2 8-bit right-aligned data |
| Bit 7: 0   | DD1DT8R  | 0x00        | rw   | DAC1 8-bit right-aligned data |

### 19.5.12 DAC1 data output register (DAC\_D1ODT)

| Bit        | Name     | Reset value | Type | Description               |
|------------|----------|-------------|------|---------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at its default value |
| Bit 11: 0  | D1ODT    | 0x000       | rw   | DAC1 output data          |

### 19.5.13 DAC2 data output register (DAC\_D2ODT)

| Bit        | Name     | Reset value | Type | Description               |
|------------|----------|-------------|------|---------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at its default value |
| Bit 11: 0  | D2ODT    | 0x000       | rw   | DAC2 output data          |

### 19.5.14 DAC status register (DAC\_STS)

| Bit        | Name      | Reset value | Type | Description                                                                                                                                            |
|------------|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved  | 0x0         | resd | Kept at its default value                                                                                                                              |
| Bit 29     | D2DMAUDRF | 0x0         | w1c  | DAC2 DMA transfer underrun flag<br>0: No DAC2 DMA transfer underrun<br>1: DAC2 DMA transfer underrun occurs<br>Note: This bit is cleared by writing 1. |
| Bit 28: 14 | Reserved  | 0x0000      | resd | Kept at its default value                                                                                                                              |
| Bit 13     | D1DMAUDRF | 0x0         | w1c  | DAC1 DMA transfer underrun flag                                                                                                                        |

|                                                                                                                     |          |        |      |                           |
|---------------------------------------------------------------------------------------------------------------------|----------|--------|------|---------------------------|
|                                                                                                                     |          |        |      |                           |
| 0: No DAC1 DMA transfer underrun<br>1: DAC1 DMA transfer underrun occurs<br>Note: This bit is cleared by writing 1. |          |        |      |                           |
|                                                                                                                     |          |        |      |                           |
| Bit 12: 0                                                                                                           | Reserved | 0x0000 | resd | Kept at its default value |

## 20 CAN

### 20.1 CAN introduction

CAN (Controller Area Network) is a distributed serial communication protocol for real-time and reliable data communication among various nodes. It supports the CAN protocol version 2.0A and 2.0B.

### 20.2 CAN main features

- Baud rates up to 1M bit/s
- Supports the time triggered communication
- Interrupt enable and mask
- Configurable automatic retransmission mode

#### Transmission

- Three transmit mailboxes
- Configurable transmit priority
- Supports the time stamp on transmission

#### Reception

- Two FIFOs with three-level depth
- 28 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 including the PROP\_SEG and PHASE\_SEG1 of the CAN standard. Its duration is between 1 and 16 time units, defined by the BTS1[3: 0] bit.

Big segment 2 (BIT SEGMENT 2): It is referred to as BSEG2 including the PHASE\_SEG2 of the CAN standard. Its duration is between 1 and 8 time units, defined by 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}$$

where

$$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, and the sampling is performed at the edge location of bit segment 1 and big segment 2 simultaneously.

During the actual transmission, each bit of the CAN nodes has certain phase error due to the oscillator drift, transmission delay among the network nodes and noise interference. To avoid the impact on the communication, the start-bit edge and its subsequent falling edge can be synchronized or resynchronized. The time length of the synchronization compensation can not be greater than the resynchronization width (1 to 4 time units, defined by the RSAW[1: 0] bit).

Figure 20-2 Transmit interrupt generation



## 20.4 Interrupt management

The CAN controller contains 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. It is activated by setting TTCEN=1 in the CAN\_MCTRL register. The internal 16-bit timer is incremented each CAN bit time, and is sampled on the Start Of Frame bit to generate the 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, CAN\_FBWCFG and CAN\_FRF registers can be modified only when FCS=1. The CAN\_FIFBx register can be modified only when FCS=1 or FAENx=0.

## 20.6 Functional overview

### 20.6.1 General description

As the number of nodes in the CAN network and the number of messages grows, an enhanced filtering mechanism is required to handle all types of messages in order to reduce the processing time of message reception. One FIFO scheme is used to ensure that the CPU can concentrate on application tasks for a long period of time without the loss of 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.

Based on the above mentioned conditions, the CAN controller provides 28 scalable/configurable identifier filter banks, 2 receive FIFOs with storing 3 complete messages each and being totally 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 request 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.

Switch 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.

Switch 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 and CAN\_MCTRL 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.

Switch 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.

Switch 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.

Switch 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.

Switch 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 combined Listen-only and 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 only recessive bits are output on the CANTX pin. In the meantime, the dominant bits output on the CANTX can be monitored 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. Meanwhile, the CAN can also send data to the external bus. The Loop back mode is mainly used for self-test functions.
- It is possible to combine the Listen-only and Loop back mode by setting the LOEN and LBEN bits in the CAN\_BTMG register. In this case, 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 28 configurable and scalable filter banks (0~27). 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 register CAN\_FiFBx includes SID[10: 0], IDT, RTR and EID[17: 15] bits

|                   |                       |                       |                  |                     |                     |
|-------------------|-----------------------|-----------------------|------------------|---------------------|---------------------|
| CAN_FiFB1[31: 21] | CAN_FiFB1<br>[20: 19] | CAN_FiFB1<br>[18: 16] | CAN_FiFB1[15: 5] | CAN_FiFB1<br>[4: 3] | CAN_FiFB1<br>[2: 0] |
| CAN_FiFB2[31: 21] | CAN_FiFB2<br>[20: 19] | CAN_FiFB2<br>[18: 16] | CAN_FiFB2[15: 5] | 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] |
| Mask    | CAN_FiFB2[31:21] | CAN_FiFB2[20:3] | CAN_FiFB2[2:0] |
| Mapping | SID[10:0]        | EID[17:0]       | IDT RTR 0      |

Figure 20-9 32-bit identifier list mode

|         |                  |                 |                |
|---------|------------------|-----------------|----------------|
| ID      | CAN_FiFB1[31:21] | CAN_FiFB1[20:3] | CAN_FiFB1[2:0] |
| ID      | CAN_FiFB2[31:21] | CAN_FiFB2[20:3] | CAN_FiFB2[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]         |
|         | CAN_FiFB1[31:24] | CAN_FiFB1[23:16]       |
| ID      | CAN_FiFB2[15:8]  | CAN_FiFB2[7:0]         |
|         | CAN_FiFB2[31:24] | CAN_FiFB2[23:16]       |
| Mapping | SID[10:0]        | RTR   IDT   EID[17:15] |

**Filter match number**

28 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.

**Priority rules**

When the CAN controller receives a frame of message, the message may pass through several filters. In this case, the filter match number stored in the receive mailbox is determined according to the following priority rules:

- A 32-bit filter has priority over a 16-bit filter
- For filters with identical bit width, the identifier list mode has priority over the identifier mask mode
- For filter with identical bit width and identifier mode, the lower number has priority over the higher number.

**Filter configuration**

- The CAN filters are configured by setting the FCS bit in the CAN\_FCTRL register.
- Identifier mask mode or identifier list mode can be selected by setting the FMSELx bit in the CAN\_FMCFG register.
- The filter bit width can be configured as two 16 bits or one 32 bits by setting the FBWSELx bit in the CAN\_FBWCFG register.
- The filter x is associated with FIFO0 or FIFO1 by setting the FRFSELx bit in the CAN\_FRF register.
- The filter banks x are activated by setting FAENx=1 in the CAN\_FACFG register.
- Configure 0~27 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, it is necessary to select one transmit mailbox and configure it through 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 pending state immediately after the mailbox is configured and the CAN controller receives the 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 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 the data transmission is complete and the mailbox becomes empty when TMxEF=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\_RFrx, CAN\_RFCx, CAN\_RFDTLx and CAN\_RFDTHx registers can be used by user applications to obtain valid messages.

### Message reception

The CAN controller boasts 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 regarded 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 receive FIFO status.

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 CAN nodes is indicated by the receive error counter (TEC) and transmit error counter (REC) bits in the CAN\_ESTS register. In the meantime, the ETR[2: 0] 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 this state, it is impossible to transmit and receive messages. The CAN resumes from bus-off state in two ways:

Option 1: When AEBOEN=0 in the CAN\_MCTRL register, in communication mode, the software requests to enter Frozen mode and exit Frozen mode, and CAN will then resume from bus-off state after 128 occurrences of 11 consecutive recessive bits have been detected on the CAN RX pin.

Option 2: When AEBOEN=1 in the CAN\_MCTRL register, 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          |
| TMI0     | 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      | 0xFFFF XXXX |
| RFC0     | 1B4h      | 0xFFFF XXXX |
| RFDTL0   | 1B8h      | 0xFFFF XXXX |
| RFDTL0   | 1BCh      | 0xFFFF XXXX |
| RFI1     | 1C0h      | 0xFFFF XXXX |
| RFC1     | 1C4h      | 0xFFFF XXXX |
| RFDTL1   | 1C8h      | 0xFFFF XXXX |
| RFDTL1   | 1CCh      | 0xFFFF XXXX |
| Reserved | 1D0h~1FFh | xx          |
| FCTRL    | 200h      | 0x2A1C 0E01 |
| FMCFG    | 204h      | 0x0000 0000 |
| Reserved | 208h      | xx          |
| FSCFG    | 20Ch      | 0x0000 0000 |
| Reserved | 210h      | xx          |
| FRF      | 214h      | 0x0000 0000 |
| Reserved | 218h      | xx          |

|          |           |             |
|----------|-----------|-------------|
| FACFG    | 21Ch      | 0x0000 0000 |
| Reserved | 220h~23Fh | xx          |
| FB0F1    | 240h      | 0xXXXX XXXX |
| FB0F2    | 244h      | 0xXXXX XXXX |
| FB1F1    | 248h      | 0xXXXX XXXX |
| FB1F2    | 24Ch      | 0xXXXX XXXX |
| ...      | ...       | ...         |
| FB27F1   | 318h      | 0xXXXX XXXX |
| FB27F2   | 31Ch      | 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 its 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 its 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   | Prohibit retransmission enable when sending fails enable<br>0: Retransmission is enabled.<br>1: Retransmission is disabled.                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 3      | MDRSEL   | 0x0         | rw   | Message discard rule select when overflow<br>0: The previous message is discarded.                                                                                                                                                                                                                                                                                                                                                                                                          |

|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | 1: The new incoming message is discarded.<br>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.                                                                                                                                                                                                                                                                                |
| Bit 2 | MMSSR | 0x0 | rw | Doze mode enable<br>0: Sleep mode is disabled.<br>1: Sleep mode is enabled.<br>Note:<br>The hardware will automatically leave sleep mode when the AEDEN is set and a message is monitored on the CAN bus.<br>After CAN reset or partial software reset, this bit is forced to be set by hardware, that is, the CAN will keep in sleep mode, by default.                                                                                                                                                       |
| Bit 1 | DZEN  | 0x1 | rw | Freeze mode enable<br>0: Freeze mode disabled<br>1: Freeze mode enabled<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 its 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 its 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.                                                                                                                                                                                                                      |

|       |      |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |      | 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><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.<br>When set, this bit will generate a status change interrupt.                                                                                                                                                                                                                                             |
| Bit 1 | DZC  | 0x1 | ro   | Doze mode acknowledge<br>0: The CAN is not in Sleep mode.<br>1: CAN is in Sleep mode.<br><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.<br><br>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><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.           |
| Bit 0 | FZC  | 0x0 | ro   | Freeze mode confirm<br>0: The CAN is not in Freeze mode.<br>1: The CAN is in Freeze mode.<br><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.<br><br>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><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.<br>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 | rw1c | Transmit mailbox 2 cancel transmit<br>0: No effect<br>1: Transmission is cancelled.<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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 19     | TM2TEF   | 0x0 | rw1c | Transmit mailbox 2 transmission error flag<br>0: No error<br>1: Mailbox 2 transmission error<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>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>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>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 TM2TSF, TM2ALF and TM2TEF bits of mailbox 2.                                                                                                                                                                                                     |
| Bit 15     | TM1CT    | 0x0 | rw1s | Transmit mailbox 1 cancel transmit<br>0: No effect<br>1: Mailbox 1 cancel transmit<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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 11     | TM1TEF   | 0x0 | rw1c | <p>Transmit mailbox 1 transmission error flag<br/>0: No error<br/>1: Mailbox 1 transmission error</p> <p>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</p>                                                                                                                                               |
| Bit 10     | TM1ALF   | 0x0 | rw1c | <p>Transmit mailbox 1 arbitration lost flag<br/>0: No arbitration lost<br/>1: Transmit mailbox 1 arbitration lost</p> <p>Note:<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</p>                                                                                                            |
| Bit 9      | TM1TSF   | 0x0 | rw1c | <p>Transmit mailbox 1 transmission success flag<br/>0: Transmission failed<br/>1: Transmission was successful.</p> <p>Note:<br/>This bit indicates whether the mailbox 1 transmission is successful or not. It is cleared by software writing 1.</p>                                                                                                                                                                              |
| Bit 8      | TM1TCF   | 0x0 | rw1c | <p>Transmit mailbox 1 transmission completed flag<br/>0: Transmission is in progress<br/>1: Transmission is completed</p> <p>Note:<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 TM1TSF, TM1ALF and TM1TEF bits of mailbox 1.</p> |
| Bit 7      | TM0CT    | 0x0 | rw1s | <p>Transmit mailbox 0 cancel transmit<br/>0: No effect<br/>1: Mailbox 0 cancel transmit</p> <p>Note: 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.</p>                                                                                                       |
| Bit 6: 4   | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 3      | TM0TEF   | 0x0 | rw1c | <p>Transmit mailbox 0 transmission error flag<br/>0: No error<br/>1: Mailbox 0 transmission error</p> <p>Note:<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</p>                                                                                                                                               |
| Bit 2      | TM0ALF   | 0x0 | rw1c | <p>Transmit mailbox 0 arbitration lost flag<br/>0: No arbitration lost<br/>1: Transmit mailbox 0 arbitration lost</p> <p>Note:<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</p>                                                                                                            |
| Bit 1      | TM0TSF   | 0x0 | rw1c | <p>Transmit mailbox 0 transmission success flag<br/>0: Transmission failed<br/>1: Transmission was successful.</p> <p>Note:</p>                                                                                                                                                                                                                                                                                                   |

|       |        |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|--------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     |      | This bit indicates whether the mailbox 0 transmission is successful or not. It is cleared by software writing 1.                                                                                                                                                                                                                                                                                                                  |
| Bit 0 | TM0TCF | 0x0 | rw1c | <p>Transmit mailbox 0 transmission completed flag<br/>0: Transmission is in progress<br/>1: Transmission is completed</p> <p>Note:<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 TM0TSF, TM0ALF and TM0TEF bits of mailbox 0.</p> |
|       |        |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 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 its default value.                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 5     | RF0R     | 0x0         | rw1s | <p>Receive FIFO 0 release<br/>0: No effect<br/>1: Release FIFO</p> <p>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.</p> <p>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.</p> |
| Bit 4     | RF0OF    | 0x0         | rw1c | <p>Receive FIFO 0 overflow flag<br/>0: No overflow<br/>1: Receive FIFO 0 overflow</p> <p>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.</p>                                                                                                                                       |
| Bit 3     | RF0FF    | 0x0         | rw1c | <p>Receive FIFO 0 full flag<br/>0: Receive FIFO 0 is not full<br/>1: Receive FIFO 0 is full</p> <p>Note:<br/>This bit is set by hardware when three messages are pending in the FIFO 0.<br/>It is cleared by software by writing 1.</p>                                                                                                                                                                   |
| Bit 2     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 1: 0  | RF0MN    | 0x0         | ro   | <p>Receive FIFO 0 message num<br/>Note:<br/>These two bits indicate how many messages are pending in the FIFO 0.</p> <p>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.</p>                            |

### 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 its default value.                                                                                                                                                                                                                                         |
| Bit 5     | RF1R     | 0x0         | rw1s | <p>Receive FIFO 1 release<br/>0: No effect<br/>1: Release FIFO</p> <p>Note:<br/>This bit is set by software to release 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.</p> |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                |
|----------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 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 4    | RF1OF    | 0x0 | rw1c | <p>Receive FIFO 1 overflow flag<br/>0: No overflow<br/>1: Receive FIFO 1 overflow</p> <p>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.</p>                                                                                                            |
| Bit 3    | RF1FF    | 0x0 | rw1c | <p>Receive FIFO 1 full flag<br/>0: Receive FIFO 1 is not full<br/>1: Receive FIFO 1 is full</p> <p>Note:<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.</p>                                                                                                                                        |
| Bit 2    | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                     |
| Bit 1: 0 | RF1MN    | 0x0 | ro   | <p>Receive FIFO 1 message num<br/>Note:<br/>These two bits indicate how many messages are pending in the FIFO 1.</p> <p>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.</p> |

### 20.7.1.6 CAN interrupt enable register (CAN\_INTEN)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 18 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                  |
| Bit 17     | EDZIEN   | 0x0         | rw   | <p>Enter doze mode interrupt enable<br/>0: Enter sleep mode interrupt disabled<br/>1: Enter sleep mode interrupt enabled</p> <p>Note: EDZIF flag bit corresponds to this interrupt. An interrupt is generated when both this bit and EDZIF bit are set.</p> |
| Bit 16     | QDZIEN   | 0x0         | rw   | <p>Quit doze mode interrupt enable<br/>0: Quit sleep mode interrupt disabled<br/>1: Quit sleep mode interrupt enabled</p> <p>Note: The flag bit of this interrupt is the QDZIF bit. An interrupt is generated when both this bit and QDZIF bit are set.</p> |
| Bit 15     | EOIEN    | 0x0         | rw   | <p>Error occur interrupt enable<br/>0: Error interrupt disabled<br/>1: Error interrupt enabled</p> <p>Note: The flag bit of this interrupt is the EOF bit. An interrupt is generated when both this bit and EOF bit are set.</p>                            |
| Bit 14: 12 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                  |
| Bit 11     | ETRIEN   | 0x0         | rw   | <p>Error type record interrupt enable<br/>0: Error type record interrupt disabled<br/>1: Error type record interrupt enabled</p> <p>Note: EOF is set only when this interrupt is enabled and the ETR[2: 0] is set by hardware.</p>                          |
| Bit 10     | BOIEN    | 0x0         | rw   | <p>Bus-off interrupt enable<br/>0: Bus-off interrupt disabled<br/>1: Bus-off interrupt enabled</p> <p>Note: EOF is set only when this interrupt is enabled and the BOF is set by hardware.</p>                                                              |
| Bit 9      | EPIEN    | 0x0         | rw   | <p>Error passive interrupt enable<br/>0: Error passive interrupt disabled<br/>1: Error passive interrupt enabled</p> <p>Note: EOF is set only when this interrupt is enabled and</p>                                                                        |

|       |          |     |      |                                                                                                                                                                                                                                                                    |
|-------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 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>Note: EOIF is set only when this interrupt is enabled and the EAF is set by hardware.                                                                |
| Bit 7 | Reserved | 0x0 | resd | Kept at its 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>Note: 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   | Receive FIFO 1 full interrupt enable<br>0: Receive FIFO 1 full interrupt disabled<br>1: Receive FIFO 1 full interrupt enabled<br>Note: The flag bit of this interrupt is the RF1FF bit. An interrupt is generated when this bit and RF1FF bit are set.             |
| Bit 4 | RF1MIEN  | 0x0 | rw   | FIFO 1 receive message interrupt enable<br>0: FIFO 1 receive message interrupt disabled<br>1: FIFO 1 receive message interrupt enabled<br>Note: The flag bit of this interrupt is RF1MN bit, so an interrupt is generated when this bit and RF1MN bit are set.     |
| Bit 3 | RF0OIEN  | 0x0 | rw   | Receive FIFO 0 overflow interrupt enable<br>0: Receive FIFO 0 overflow interrupt disabled<br>1: Receive FIFO 0 overflow interrupt enabled<br>Note: The flag bit of this interrupt is RF0OF bit, so an interrupt is generated when this bit and RF0OF bit are set.  |
| Bit 2 | RF0FIEN  | 0x0 | rw   | Receive FIFO 0 full interrupt enable<br>0: Receive FIFO 0 full interrupt disabled<br>1: Receive FIFO 0 full interrupt enabled<br>Note: The flag bit of this interrupt is the RF0FF bit. An interrupt is generated when this bit and RF0FF bit are set              |
| Bit 1 | RF0MIEN  | 0x0 | rw   | FIFO 0 receive message interrupt enable<br>0: FIFO 0 receive message interrupt disabled<br>1: FIFO 0 receive message interrupt enabled<br>Note: The flag bit of this interrupt is the RF0MN bit. An interrupt is generated when this bit and RF0MN bit are set     |
| Bit 0 | TCIEN    | 0x0 | rw   | Transmit mailbox empty interrupt enable<br>0: Transmit mailbox empty interrupt disabled<br>1: Transmit mailbox empty interrupt enabled<br>Note: The flag bit of this interrupt is the TMxTCF bit. An interrupt is generated when this bit and TMxTCF bit are set   |

### 20.7.1.7 CAN error status register (CAN\_ESTS)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                       |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | REC      | 0x00        | ro   | Receive error counter<br>This counter is implemented in accordance with the receive part of the fault confinement mechanism of the CAN protocol.                                                                  |
| Bit 23: 16 | TEC      | 0x00        | ro   | Transmit error counter<br>This counter is implemented in accordance with the transmit part of the fault confinement mechanism of the CAN protocol.                                                                |
| Bit 15: 7  | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                        |
| Bit 6: 4   | ETR      | 0x0         | rw   | Error type record<br>000: No error<br>001: Bit stuffing error<br>010: Format error<br>011: Acknowledgement error<br>100: Recessive bit error<br>101: Dominant bit error<br>110: CRC error<br>111: Set by software |

|       |          |     |      |                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                       |
|-------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      |                                                                                                                                                                                                                                                                     | Note:<br>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.<br>If the error code 7 is not used by hardware, this field can be set by software to monitor the code update. |
| Bit 3 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                       |
| Bit 2 | BOF      | 0x0 | ro   | Bus-off flag<br>0: Bus-off state is not entered.<br>1: Bus-off state is entered.<br>Note: When the TEC is greater than 255, the bus-off state is entered, and this bit is set by hardware.                                                                          |                                                                                                                                                                                                                                                                                                                                                       |
| Bit 1 | EPF      | 0x0 | ro   | Error passive flag<br>0: Error passive state is not entered<br>1: Error passive state is entered<br>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 >127) |                                                                                                                                                                                                                                                                                                                                                       |
| Bit 0 | EAF      | 0x0 | ro   | Error active flag<br>0: Error active state is not entered<br>1: Error active state is entered<br>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)      |                                                                                                                                                                                                                                                                                                                                                       |

### 20.7.1.8 CAN bit timing register (CAN\_BTMG)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | LOEN     | 0x0         | rw   | Listen-Only mode<br>0: Listen-Only mode disabled<br>1: Listen-Only mode enabled                                                                                                     |
| Bit 30     | LBEN     | 0x0         | rw   | Loop back mode<br>0: Loop back mode disabled<br>1: Loop back mode enabled                                                                                                           |
| Bit 29: 26 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                          |
| Bit 25: 24 | RSAW     | 0x1         | rw   | Resynchronization width<br>$tRSAW = tCAN x (RSAW[1: 0] + 1)$<br>Note: This field defines the maximum of time unit that the CAN hardware is allowed to lengthen or shorten in a bit. |
| Bit 23     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                          |
| Bit 22: 20 | BTS2     | 0x2         | rw   | Bit time segment 2<br>$tBTS2 = tCAN x (BTS2[2: 0] + 1)$<br>Note: This field defines the number of time unit in Bit time 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 its default value.                                                                                                                                                          |
| Bit 11: 0  | BRDIV    | 0x000       | rw   | Baud rate division<br>$tq = (BRDIV[11: 0]+1) \times 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 [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. TMxEF=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 | 0xXXX       | 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        | 0XXXXX      | rw   | Transmit mailbox extended identifier<br>Note: This field defines the 18-bit low bytes of the extended identifier.                                                                  |
| Bit 2      | TMIDSEL      | 0xX         | rw   | Transmit mailbox identifier type select<br>0: Standard identifier<br>1: Extended identifier                                                                                        |
| Bit 1      | TMFRSEL      | 0xX         | 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     | 0XXXXX      | 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 | 0XX         | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                   |
| Bit 8      | TMTSTEN  | 0X          | rw   | 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 | 0X          | resd | Kept at its default value                                                                                                                                                                                                                                                                                                                                   |
| Bit 3: 0   | TMDTBL   | 0X          | 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       | 0X          | ro   | Receive FIFO identifier type indication<br>0: Standard identifier<br>1: Extended identifier                                                                               |
| Bit 1      | RFFRI       | 0X          | ro   | Receive FIFO frame type indication<br>0: Data frame<br>1: Remote frame                                                                                                    |
| Bit 0      | Reserved    | 0X          | resd | Kept at its 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    | 0X          | ro   | Receive FIFO filter match number<br>Note: This field contains the filter number that a message has passed through.                                                                                      |
| Bit 7: 4   | Reserved | 0X          | resd | Kept at its default value                                                                                                                                                                               |
| Bit 3: 0   | RFDTL    | 0X          | 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\_RFDTHx) (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><i>Note: The initialization of the filter bank can be configured only when it is in configuration mode.</i> |

### 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: 28 | Reserved | 0x00000     | resd | Kept at its default value                                                                                          |
| Bit 27: 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: 28 | Reserved | 0x00000     | resd | Kept at its default value                                                                               |
| Bit 27: 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: 28 | Reserved | 0x00000     | resd | Kept at its default value                                                                                                     |
| Bit 27: 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: 28 | Reserved | 0x00000     | resd | Kept at its default value                                                                   |
| Bit 27: 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 | 0xXXXX XXXX | 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 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 Universal serial bus full-speed device interface (OTGFS)

As a full-speed dual-role device, the OTGFS is fully compliant with the Universal Serial Bus Specification Revision2.0.

## 21.1 USBFS structure

Figure 21-1 shows the block diagram of the OTGFS structure. The OTGFS module is connected to the AHB and has a dedicated SRAM of 1280 bytes.

Figure 21-1 Block diagram of OTGFS structure



## 21.2 OTGFS functional description

Two independent OTGFS modules are embedded in the device. The OTGFS module consists of an OTGFS controller, PHY and 1280-byte SRAM.

The OTGFS supports control transfer, bulk transfer, interrupt transfer and synchronous transfer.

The OTGFS is a USB full-speed dual role device controller. The status of the ID line determines whether the OTGFS acts as a host or device. When the ID line is floating, the OTGFS is used as a device. It is used as a host while the ID line is grounded. The internal 1.5KΩ pull-up resistor and 1.5KΩ pull-down resistor are available in the OTG PHY for the sake of dual role device.

In device mode, the OTGFS supports one bidirectional control endpoint, 7 IN endpoints, and 7 OUT endpoints; in host mode, the OTGFS supports 16 host channels.

The OTGFS supports SOF and OE pulse features: a SOF pulse generates at a SOF packet, the pulse can output to pins and the timer 2; an OE pulse generates when the OTGFS outputs data, the pulse can output to pins.

Suspend mode is supported. The OTGFS goes into power-saving mode after Suspend mode is entered.

As a device, a unified FIFO buffer is allocated for all OUT endpoints, and a separate FIFO buffer is provided to each of IN endpoints. As a host, a unified receive FIFO is allocated for all receive channels, a unified transmit FIFO for all non-periodic transmit channels, and a unified transmit FIFO for all periodic transmit channels.

If the STOPPCLK is set in the OTGFS\_PCGCCTL register, the OTGFS enters Suspend mode when the bus signal is not received for 3ms. The LP\_MODE bit in the OTGFS\_GCCFG register can be used to disable PHY receive in order to reduce power consumption.

## 21.3 OTGFS clock and pin configuration

### 21.3.1 OTGFS clock configuration

The OTGFS interface has two clocks: USB control clock and APB bus clock. The USB full-speed device bus speed standard is 12Mb/s $\pm$ 0.25%, so it is necessary to supply 48MHz $\pm$ 0.25% for the OTGFS to perform USB bus sampling.

USBFS 48M clock has two sources:

- HICK 48M  
When the HICK 48M clock is used as a USB control clock, it is recommended to enable ACC feature.
- Divided by PLL  
The PLL output frequency must ensure that the USBDIV (see CRM\_CFG register) can be divided to 48MHz.

*Note: The APB clock frequency must be greater than 30MHz when OTGFS is enabled.*

### 21.3.2 OTGFS pin configuration

When the USB module is enabled in the CRM, PA11 and PA12 can be multiplexed as DP/DM; PA8 can be multiplexed as SOF output and configured as a push-pull multiplexed output feature.

The OTGFS input/output pins are multiplexed with GPIOs. The GPIOs are used as OTGFS in one of the following conditions:

Table 21-1 OTGFS input/output pins

| Pin         | GPIO | Description                                                                                                   |
|-------------|------|---------------------------------------------------------------------------------------------------------------|
| OTGFS1_SOF  | PA8  | Enable OTG1 in CRM, and configure PA8 multiplexed function register as 0xA                                    |
| OTGFS1_VBUS | PA9  | Configure PA9 as multiplexed function mode and PA9 multiplexed function register as 0xA                       |
| OTGFS1_ID   | PA10 | Enable OTG1 in CRM, configure PA10 as multiplexed function mode and PA10 multiplexed function register as 0xA |
| OTGFS1_D-   | PA11 | Enable OTG1 in CRM, configure PA11 multiplexed function register as 0xA, and set PWRDOWN=1                    |
| OTGFS1_D+   | PA12 | Enable OTG1 in CRM, configure PA12 multiplexed function register as 0xA, and set PWRDOWN=1                    |
| OTGFS1_OE   | PA13 | Enable OTG1 in CRM, and configure PA13 multiplexed function register as 0xA                                   |
| OTGFS2_SOF  | PA4  | Enable OTG2 in CRM, and configure PA4 multiplexed function register as 0xC                                    |
| OTGFS2_VBUS | PB13 | Configure PB13 as multiplexed function mode and PB13 multiplexed function register as 0xC                     |
| OTGFS2_ID   | PB12 | Enable OTG2 in CRM, configure PB12 as multiplexed function mode and PB12 multiplexed function register as 0xC |
| OTGFS2_D-   | PB14 | Enable OTG2 in CRM, configure PB14 multiplexed function register as 0xC, and set PWRDOWN=1                    |
| OTGFS2_D+   | PB15 | Enable OTG2 in CRM, configure PB15 multiplexed function register as 0xC                                       |

|           |     |                                                                            |
|-----------|-----|----------------------------------------------------------------------------|
|           |     | as 0xC, and set PWRDOWN=1                                                  |
| OTGFS2_OE | PC9 | Enable OTG2 in CRM, and configure PC9 multiplexed function register as 0xB |

## 21.4 OTGFS interrupts

Figure 21-2 shows the OTGFS interrupt hierarchy. Refer to the OTGFS interrupt register (OTGFS\_GINTSTS) and OTGFS interrupt mask register (OTGFS\_GINTMSK).

Figure 21-2 OTGFS interrupt hierarchy



## 21.5 OTGFS functional description

### 21.5.1 OTGFS initialization

If the cable is connected during power-on, the current operation mode bit (CURMOD bit) in the controller interrupt register indicates the mode. The OTGFS controller enters host mode when A-type plug is connected or device mode when a B-type plug is connected.

This section explains the initialization of the OTGFS controller after power-on. The application must follow the initialization sequence, however in host or device mode. All controller global registers are initialized according to the controller configuration.

1. Program the following fields in the global AHB configuration register:

- Global interrupt mask bit = 0x1
  - Non-periodic transmit FIFO empty level
  - Periodic transmit FIFO empty level
2. Program the following fields in the global AHB configuration register:
    - OTGFS\_GINTMSK.RXFLVLMSK = 0x0
  3. Program the following fields in the OTGFS\_GUSBCFG register:
    - Full-speed timeout standard bit
    - USB turnaround time bit
  4. The software must unmask the following bits in the OTGFS\_GINTMSK register:
    - OTG interrupt mask
    - Mode mismatch interrupt mask
  5. The software can read the CURMOD bit in the OTGFS\_GINTSTS register to determine whether the OTGFS controller is operating in host or device mode.

## 21.5.2 OTGFS 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 modifying FIFO SRAM allocation.

- OTGFS\_DIEPCTLx/ OTGFS\_DOEPCTLx.EPENA = 0x0
- OTGFS\_DIEPCTLx/ OTGFS\_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 during 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 control endpoint. The controller does not use these locations, which are reserved for SETUP packets.
- One WORD is to be 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. 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 for each endpoint, is also pushed to 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 more 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-2 OTGFS 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 receive FIFO size register (OTGFS\_GRXFSIZ)

- OTGFS\_GRXFSIZ.RXFDEP = rx\_fifo\_size
- 2. Endpoint 0 TX FIFO size register (OTGFS\_DIEPTXF0)
  - OTGFS\_DIEPTXF0.INEPT0TXDEP = tx\_fifo\_size[0]
  - OTGFS\_DIEPTXF0.INEPT0TXSTADDR = rx\_fifo\_size
- 3. Device IN endpoint transmit FIFO#1 size register (OTGFS\_DIEPTXF1)
  - OTGFS\_DIEPTXF1.INEPTXFSTADDR = OTGFS\_DIEPTXF0.INEPT0TXSTADDR + tx\_fifo\_size[0]
- 4. Device IN endpoint transmit FIFO#2 size register (OTGFS\_DIEPTXF2)
  - OTGFS\_DIEPTXF2.INEPTXFSTADDR = OTGFS\_DIEPTXF1.INEPTXFSTADDR + tx\_fifo\_size[1]
- 5. Device IN endpoint transmit FIFO#i size register (OTGFS\_DIEPTXF*i*)
  - OTGFS\_DIEPTXF*i*.INEPTXFSTADDR = OTGFS\_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\_GRSTCTL.TXFNUM = 0x10
  - OTGFS\_GRSTCTL.TXFFLSH = 0x1
  - OTGFS\_GRSTCTL.RXFFLSH = 0x1

The application cannot perform other 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\_GRSTCTL register.

After allocation, the FIFO pointers must be reset by refreshing operation to ensure normal FIFO running. 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 WORDs 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.

### (3) Internal storage space allocation

Table 21-3 OTGFS internal 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 receive FIFO size register (OTGFS\_GRXFSIZ)
  - OTGFS\_GRXFSIZ.RXFDEP = rx\_fifo\_size
2. OTGFS Non-periodic TX FIFO size register (OTGFS\_GNPTXFSIZ)
  - OTGFS\_GNPTXFSIZ.NPTXFDEP = tx\_fifo\_size[0]
  - OTGFS\_GNPTXFSIZ.NPTXFSTADDR = rx\_fifo\_size
3. OTGFS host periodic transmit FIFO size register (OTGFS\_HPTXFSIZ)
  - OTGFS\_HPTXFSIZ.PTXFSIZE = tx\_fifo\_size[1]
  - OTGFS\_HPTXFSIZ.PTXFSTADDR = OTGFS\_GNPTXFSIZ.NPTXFSTADDR + tx\_fifo\_size[0]
4. After SRAM allocation, refresh transmit FIFO and receive FIFO to ensure normal FIFO running.
  - OTGFS\_GRSTCTL.TXFNUM = 0x10
  - OTGFS\_GRSTCTL.TXFFLSH = 0x1
  - OTGFS\_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\_GRSTCTL register:

- Check whether GINNAKEFF=0 or not in the OTGFS\_GINTSTS register. If this bit has been cleared, write 0x1 to the OTGFS\_DCTL.SGNPINNAK register. When the NACK valid interrupt is set, it means that the controller does not read FIFO.
- Wait until GINNAKEFF = 0x1 in the OTGFS\_GINTSTS register, indicating that the NAK configuration has taken effect for all IN endpoints.
- Poll the OTGFS\_GRSTCTL register and wait until AHBIDLE=1. AHBIDLE = H indicates that the controller does not write the FIFO.
- Confirm whether TXFFLSH = 0x0 or not in the OTGFS\_GRSTCTL register. If TXFFLSH is cleared, write the transmit FIFO number to be refreshed into the OTGFS\_GRSTCTL.TXFNUM register.
- Set TXFFLSH = 0x1 in the OTGFS\_GRSTCTL register, and wait until it is cleared.
- Set the CGNPINNAK bit in the OTGFS\_DCTL register.

### 21.5.3 OTGFS host mode

#### 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\_GINTMSK register
2. Program the OTGFS\_HCFG register
3. Set PRTPWR = 0x1 in the OTGFS\_HPRT register to drive VBUS supply on the USB
4. Wait until that the PRTCDETbit is set in the OTGFS\_HPRT0 register, indicating that the device is connected to the port
5. Set PRTRST = 0x1 in the OTGFS\_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\_HPRT register
8. Wait for the interrupt (PRTENCHNG bit in the OTGFS\_HPRT register)
9. Read the PRTSPD bit in the OTGFS\_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\_GRXFSIZ register
12. Select the start address and size of the non-periodic transmit FIFO by setting the OTGFS\_GNPTXFSIZ register
13. Select the start address and size of the periodic transmit FIFO by setting the OTGFS\_HPTXFSIZ register

To communicate with the device, the application must enable and initialize at least one channel according to OTGFS channel initialization requirements.

### 21.5.3.2 OTGFS 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\_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\_HAINTMSK register
3. Unmask the transfer-related interrupts in the host channel interrupt register by setting the OTGFS\_HCINTMSKx register
4. Configure the total transfer size (in bytes), and the expected number of the packets (including short packets) for the OTGFS\_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\_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\_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\_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-period 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\_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\_HCINTx register during a non-periodic IN transfer
- When an STALL , XACTERR , BBLERR or DTGLERR interrupt in the OTGFS\_HCINTx register is received for an IN or OUT channel
- When a DISCONINT (device disconnected) interrupt event is received in the OTGFS\_GINTSTS register, the application must check the PRTCONSTS bit in the OTGFS\_HPRT register. This is because when the device is disconnected with the host, the PRTCONSTS bit will be reset in the OTGFS\_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 synchronous 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-3 shows the flow chart of writing the transmit FIFO. The OTGFS host automatically writes a request (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 host determines the actual packet size according to the programmed maximum packet size and transfer size.

Figure 21-3 Writing the transmit FIFO



- Reading the receive FIFO

Figure 21-4 shows the flow chart of reading the receive FIFO. The application must ignore all packet statuses other than IN data packet (0x0010)

Figure 21-4 Reading the receive FIFO



### 21.5.3.5 Special cases

#### (1) Handling babble conditions

The OTGFS 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 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 flushes the data already written in the receiver buffer and generates a babble interrupt.

When the OTGFS 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\_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\_GINTSTS register). Upon receiving this interrupt, the application must start a software reset through the CSFTRST in the OTGFS\_GRSTCTL register.

### 21.5.3.6 Host HFIR feature

The host frame interval register (HFIR) defines the interval between two consecutive SOFs (full-speed) 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 based on PHY clock frequencies.

Figure 21-5 shows the HFIR behavior when the HFIRRLDCTRL is set to 0x0 in the OTGFS\_HFIR register.

Figure 21-5 HFIR behavior when HFIRRLDCTRL=0x0



The sequence of operation is as follows:

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. The HFIR downcounter is reloaded, so it will immediately restart counting to cause SOF synchronization loss
4. Restart HFIR counter
5. The HFIR register receives a new programmed value
6. Obtain SOF synchronization again after the first SOF is generated using the HFIR new feature

Figure 21-6 shows the HFIR behavior when HFIRRLDCTRL=0x1 in the OTGFS\_HFIR register.

Figure 21-6 HFIR behavior when HFIRRLDCTRL=0x1



The sequence of operation is as follows:

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-7 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 64 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 sequence of operations shown in Figure 21-7 is as follows:

1. Initialize channel 2 (according to OTGFS channel initialization requirements)
2. Set the CHENA bit in the OTGFS\_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 as soon as 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\_HCCHAR2 register. The controller writes a channel halted request to the non-periodic request queue once the OTGFS\_HCCHAR2 register is written
10. The controller generates the RXFLVL interrupt as soon as the halt status is written to the receive FIFO
11. Read and ignore the receive packet status
12. The controller generates a CHHLTD interrupt as soon as 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-7 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 64 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 sequence of operations shown in Figure 21-7 is as follows:

1. Initialize channel 1 (according to OTGFS 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 as soon as 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-7 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 spaces. The application must check whether there is a free space in the transmit FIFO through the NPTXFEMP bit in the OTGFS\_GINTSTS register.
- The application can only write a request when the request queue has free spaces and wait until an XFERC interrupt is received.

### 21.5.3.9 Initialize interrupt IN transfers

Figure 21-8 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 64 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 sequence of operations shown in Figure 21-8 (channel 2) is as follows:

1. Initialize channel 2 (according to OTGFS channel initialization requirements). The application must set the ODDFRM bit in the OTGFS\_HCCHAR2 register
2. Set the CHENA bit in the OTGFS\_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\_HCCHAR2 register

4. The OTGFS host attempts to send an IN token in the next frame (odd)
5. The OTGFS 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\_HCTSIZ2 register. If the PKTCNT bit in the OTGFS\_HCTSIZ2 is not equal to 0, disable the channel before re-initializing the channel for the next transfer. If PKTCNT == 0 in the OTGFS\_HCTSIZ2 register, re-initialize the channel for the next transfer. In this case, the application must reset the ODDFRM bit in the OTGFS\_HCCHAR2 register.

## (2) Handling interrupts

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 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
}
```

The application can only write a request 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 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 64 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 sequence of operations shown in Figure 21-8 (channel 1) is as follows:

1. Initialize channel 1 (according to OTGFS channel initialization requirements). The application must set the ODDFRM bit in the OTGFS\_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) Handling interrupts

Figure 21-8 shows an example of common interrupt OUT/IN transfers

Figure 21-8 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 based on the number defined in the MC filed to the transmit FIFO and request queue 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\_GINTSTS register.

### 21.5.3.11 Initialize synchronous IN transfers

Figure 21-9 shows the operation process of a typical synchronous 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 1023 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 interrupt IN operation process

The sequence of operations shown in Figure 21-9 (channel 2) is as follows:

1. Initialize channel 2 (according to OTGFS channel initialization requirements). The application must set the ODDFRM bit in the OTGFS\_HCCHAR2 register
2. Set the CHENA bit in the OTGFS\_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\_HCCHAR2 register
4. The OTGFS host attempts to send an IN token in the next frame (odd)
5. The OTGFS 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\_HCTSIZ2 register. If the PKTCNT bit in the OTGFS\_HCTSIZ2 is not equal to 0, disable the channel before re-initializing the channel for the next transfer. If PKTCNT == 0 in the OTGFS\_HCTSIZ2 register, re-initialize the channel for the next transfer. In this case, the application must reset the ODDFRM bit in the OTGFS\_HCCHAR2 register.

## (2) Handling interrupts

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 synchronous OUT transfers

Figure 21-9 shows a typical synchronous 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 1023 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 interrupt IN operation process

The sequence of operations shown in Figure 21-9 (channel 2) is as follows:

1. Initialize channel 1 (according to OTGFS channel initialization requirements). The application must set the ODDFRM bit in the OTGFS\_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 OTGFS 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) Handling interrupts

Figure 21-9 shows an example of common synchronous OUT transfers

Figure 21-9 Example of common synchronous 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 (CHHLTD)
{
    Mask CHHLTD
    De-allocate Channel
}
```

## 21.5.4 OTGFS device mode

### 21.5.4.1 Device initialization

The application must perform the following steps to initialize the controller during power-on or after switching a mode from host to device:

1. Program the following fields in the OTGFS\_DCFG register
  - Device speed
  - Non-zero-length status OUT handshake
  - Periodic frame interval
2. Clear the SFTDISCON bit in the OTGFS\_DCTL register. The controller will start connection after clearing this bit
3. Program the OTGFS\_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\_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\_GINTSTS register. It indicates the end of USB reset. Upon receiving this interrupt, the application must read the OTGFS\_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 NAB bit for all OUT endpoints
  - OTGFS\_DOEPCtlx.SNAK = 0x1(for all OUT endpoints)
2. Unmask the following interrupt bits
  - OTGFS\_DAINTMSK.INEP0 = 0x1(control IN endpoint 0)
  - OTGFS\_DAINTMSK.OUTEP0 = 0x1(control OUT endpoint 0)
  - OTGFS\_DOEPMASK.SETUP = 0x1
  - OTGFS\_DOEPMASK.XFERC = 0x1
  - OTGFS\_DIEPMASK.XFERC = 0x1
  - OTGFS\_DIEPMASK.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\_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\_DIEPTXF0 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\_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\_DSTS register to get the enumeration speed.
- Program the MPS bit in the OTGFS\_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\_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 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\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTGFS\_DOEPTLx register (for OUT or bidirectional endpoints)

- Largest packet size
- USB valid endpoint = 0x1
- 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\_DIEPCTLx register (for IN or bidirectional endpoints) or the OTGFS\_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\_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\_DOEPTSIZx 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 based on 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\_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\_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\_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\_DOEPINTx register
- Repeat above-mentioned steps until an interrupt (XFERC bit in the OTGFS\_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\_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\_DOEPTSIZx 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\_DIEPINTx register for each IN transfer on the endpoint
- When the XFERC interrupt is set in the OTGFS\_DOEPINTx 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 NZSTSOUTSHSHK bit in the OTGFS\_DCFG register, and then send data OUT transfer at status stage

The XFERC interrupt bit is set in the OTGFS\_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\_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\_DOEPTSIz 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\_DOEPCTLx.EPENA = 0x1
  - The application must program the registers in the controller to perform the received SETUP commands
3. For status IN stage, the application must program the registers based on Non-periodic (bulk and control) IN data transfers to perform data IN transfers
4. The XFERC interrupt bit is set in the OTGFS\_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\_GRXSTSP register as soon as the RXFLVL interrupt bit is detected in the OTGFS\_GINTSTS register
2. The application can mask the RXFLVL interrupt bit in the OTGFS\_GINTSTS register by setting RXFLVL = 0x0 in the OTGFS\_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 = Don't Care (0x0) and DPID = Don't 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\_GRXSTSR / OTGFS\_GRXSTSP register

7. After the valid data is popped from the receive FIFO, the RXFLVL interrupt bit in the OTGFS\_GINTSTS register must be unmasked
8. Step 1-5 must be repeated each time the application detects the interrupt line due to the RXFLVL bit in the OTGFS\_GINTSTS register. Reading an empty receive FIFO will result in unexpected behavior. Figure 21-10 shows a flowchart.

Figure 21-10 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 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\_DOEPTSI $_Zx$ ) 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\_DOEPCTL $_x$  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\_DOEPTSI $_Zx$ .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 are required for one SETUP packet, one WORD is required for the Setup stage and 8 WORDs are required to store 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\_DOEPINT $_x$  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\_DOEPTSI $_Zx$  register

- OTGFS\_DOEPTSIx.SUPCNT = 0x3
2. Wait for the RXFLVL interrupt bit in the OTGFS\_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\_DOEPINTx register, it indicates that the SETUP data transfer has been completed successfully. Upon this interrupt, the application must read the OTGFS\_DOEPTSIx register to determine the number of SETUP packets received, and process the last received SETUP packet.

Figure 21-11 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\_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\_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\_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\_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 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\_DIEPTSIZx register according to the transfer size and the corresponding packet count.
2. Program the OTGFS\_DIEPCTLx 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\_DTXFSTSx 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\_DIEPINTx 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 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 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\_DOEPTSIZx register with the transfer size and the corresponding packet count.

2. Program the OTGFS\_DOEPCTLx register with the endpoint characteristics, and set the endpoint enable and ClearNAK bits.

- OTGFS\_DOEPCTLx.EPENA = 0x1
- OTGFS\_DOEPCTLx.CNAK = 0x1

3. Wait for the RXFLVL interrupt in the OTGFS\_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\_DOEPINTx register, it indicates a successful completion of the non-synchronous OUT data transfer. Read the OTGFS\_DOEPTSIZx register to determine how much data has been received.

#### [Bulk OUT transfer]

Figure 21-12 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-12 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 OYG\_DOEPCTLx register, and setting the XFERSIZE and PKTCNT bits in the OTGFS\_DOEPTSIx 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\_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\_DOEPINTx register.
7. The application processes the interrupt and uses the XFERC bit in the OTGFS\_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 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 ≤ packet count [epnum] ≤ 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\_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\_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\_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\_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\_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\_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\_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\_GINTSTS register. See “Incomplete synchronous OUT data transfers” for more information.
6. Read the OTGFS\_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\_DOEPTSIZx.RxDPID = 0xD0 and the USB packet count in which the payload was received =0x1
  - OTGFS\_DOEPTSIZx.RxDPID = 0xD1 and the USB packet count in which the payload was received =0x2
  - OTGFS\_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-programed 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 controller is based on a single-transfer level. The application must re-configure the controller on every frame. The OTGFS 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 controller schedules the synchronous transfers by setting Even/Odd frame bits.

### [Synchronous IN transfer interrupt]

The following interrupts must be processed to ensure successful scheduling of the synchronous transfers.

- XFERC interrupt in the OTGFS\_DIEPINTx register (for endpoints)
- OTG INCOMPISOIN interrupt in the OTGFS\_GINTSTS register (for global interrupts)

### [Handling synchronous IN transfers]

The following steps must be performed to handle a synchronous IN transfer:

1. Unmask the incompISOOUT interrupt in the OTGFS\_GINTSTS register by setting the INCOMISOINMSK interrupt bit in the OTGFS\_GINTMSK register

2. Unmask the XFERC interrupt in the OTGFS\_DIEPINTx register by setting the XFERCMASK bit in the OTGFS\_DIEPMASK register

3. Enable synchronous endpoints with the following steps:

- Program the OTGFS\_DIEPTSIzX register

OTGFS\_DIEPTSIzX.XFERSIZE= n \* OTGFS\_DIEPCTLx.MPS + sp, where 0 <= n <= 3 and 0 <= sp < OTGFS\_DIEPCTLx.MPS. When the transfer size in a frame is less than that of the MPS bit in the OTGFS\_DIEPCTLx register, n=0; When the transfer size in a frame is a multiple of that of the MPS bit in the OTGFS\_DIEPCTLx register, sp=0.

OTGFS\_DIEPTSIzX.PKTCNT = 0x1

The MC bit in the OTGFS\_DIEPTSIzX register is set the same value as that of the PKTCNT bit in the OTGFS\_DIEPTSIzX register.

- Program the OTGFS\_DIEPCTLx register

Read the OTGFS\_DSTS register to determine the current frame number

Program the OTGFS\_DIEPCTLx with the maximum packet size (MPS bit)

Set USBACTEP = 0x1 in the OTGFS\_DIEPCTLx register

Set EPTYPE = 0x1 in the OTGFS\_DIEPCTLx register, marking synchronization

Set the FIFO number of the endpoint through the TXFNUM bit in the OTGFS\_DIEPCTLx register

Set CNAK = 0x1 in the OTGFS\_DIEPCTLx register

If SOFFN[0] = 0x0 in OTGFS\_DSTS, then SETEVENFR = 0x1 in OTGFS\_DIEPCTLx (otherwise, SETEVENFR = 0x1 in OTGFS\_DIEPCTLx)

If SOFFN[0] = 0x1 in OTGFS\_DSTS, then SETODDFR = 0x1 in OTGFS\_DIEPCTLx (otherwise, SETODDFR = 0x0 in OTGFS\_DIEPCTLx)

Set EPENA = 0x1 in OTGFS\_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\_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\_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\_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\_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\_DIEPCTLx register, write 1 to the SETD0PID bit in the OTGFS\_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\_DIEPCTLx register, write 1 to the SETD1PID bit in the OTGFS\_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 synchronous OUT data transfers

To initialize the controller after power-on reset, the application must perform the steps list in OTGFS 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]

1. For synchronous OUT endpoints, the XFERC interrupt (in the OTGFS\_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\_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

2. 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\_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]

1. 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.

2. 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\_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"

3. 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\_DOEPCTLx. Even/Odd frame bit= OTGFS\_DSTS.SOFFN[0]
- OTGFS\_DOEPCTLx. 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\_DOEPCTLx register.

6. Wait for the endpoint disable interrupt in the OTGFS\_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 synchronous 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\_DIEPINTx register. The application ignores this interrupt, which will result in the generation of the incomplete synchronous IN transfer interrupt (in OTGFS\_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\_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\_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\_DIEPCTLx register
  - OTGFS\_DIEPCTLx.SETNAK = 0x1
  - OTGFS\_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\_GRSTCTL register.

#### 21.5.4.20 Periodic IN (interrupt and synchronous) 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 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] = 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] = packet count [epnum]
- 2. The application can only schedule data transfers of one frame at a time
  - $(\text{OTGFS\_DIEPTSIZx.MC} - 1) * \text{OTGFS\_DIEPCTLx.MPS} \leq \text{OTGFS\_DIEPTSIZx.XFERSIZ}$   
 $\leq \text{OTGFS\_DIEPTSIZx.MC} * \text{OTGFS\_DIEPCTLx.MPS}$
  - $\text{OTGFS\_DIEPTSIZx.PKTCNT} = \text{OTGFS\_DIEPTSIZx.MC}$
  - If  $\text{OTGFS\_DIEPTSIZx.XFERSIZ} < \text{OTGFS\_DIEPTSIZx.MC} * \text{OTGFS\_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 PERPRINT bit in the OTGFS\_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\_GINTSTS register.

#### [Application programming sequence (frame transfers)]

1. Program the OTGFS\_DIEPTSIZx register
2. Program the OTGFS\_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\_DIEPINTx register) on the periodic interrupt IN endpoints.
7. The assertion of the XFERC interrupt in the OTGFS\_DIEPINTx register but without the INTKNTXFEMP interrupt indicates the successful completion of a synchronous IN transfer. When reading the OTGFS\_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\_DIEPINTx register, with or without the INTKNTXFEMP interrupt, indicates the successful completion of an interrupt IN transfer. When reading the OTGFS\_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 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 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\_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-13 CSR memory map



x = 7 in device mode, x =15 in host mode.

The OTGFS control and status registers contain OTGFS global register, host mode register, device mode register, data FIFO register, power and clock control register.

1. OTGFS 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 in 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 register address map

Table 21-4 shows the USB OTG register map and their reset values.

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

Table 21-4 OTGFS register map and reset values

| Register                           | Offset | Reset value |
|------------------------------------|--------|-------------|
| OTGFS_GOTGCTL                      | 0x000  | 0x0001 0000 |
| OTGFS_GOTGINT                      | 0x004  | 0x0000 0000 |
| OTGFS_GAHBCFG                      | 0x008  | 0x0000 0000 |
| OTGFS_GUSBCFG                      | 0x00C  | 0x0000 1440 |
| OTGFS_GRSTCTL                      | 0x010  | 0x8000 0000 |
| OTGFS_GINTSTS                      | 0x014  | 0x0400 0020 |
| OTGFS_GINTMSK                      | 0x018  | 0x0000 0000 |
| OTGFS_GRXSTSR                      | 0x01C  | 0x0000 0000 |
| OTGFS_GRXSTSP                      | 0x020  | 0x0000 0000 |
| OTGFS_GRXFSIZ                      | 0x024  | 0x0000 0200 |
| OTGFS_GNPTXFSIZ/<br>OTGFS_DIEPTXF0 | 0x028  | 0x0200 0200 |
| OTGFS_GNPTXSTS                     | 0x02C  | 0x0008 0200 |
| OTGFS_GCCFG                        | 0x038  | 0x0000 0000 |
| OTGFS_GUID                         | 0x03C  | 0x0000 1000 |
| OTGFS_HPTXFSIZ                     | 0x100  | 0x0200 0400 |
| OTGFS_DIEPTXF1                     | 0x104  | 0x0000 0000 |
| OTGFS_DIEPTXF2                     | 0x108  | 0x0000 0000 |
| OTGFS_DIEPTXF3                     | 0x10C  | 0x0000 0000 |
| OTGFS_DIEPTXF4                     | 0x110  | 0x0000 0000 |
| OTGFS_DIEPTXF5                     | 0x114  | 0x0000 0000 |
| OTGFS_DIEPTXF6                     | 0x118  | 0x0000 0000 |
| OTGFS_DIEPTXF7                     | 0x11C  | 0x0000 0000 |
| OTGFS_HCFG                         | 0x400  | 0x0000 0000 |
| OTGFS_HFIR                         | 0x404  | 0x0000 EA60 |
| OTGFS_HFNUM                        | 0x408  | 0x0000 3FFF |

|                 |       |             |
|-----------------|-------|-------------|
| OTGFS_HPTXSTS   | 0x410 | 0x0008 0100 |
| OTGFS_HAINT     | 0x414 | 0x0000 0000 |
| OTGFS_HAINTMSK  | 0x418 | 0x0000 0000 |
| OTGFS_HPRT      | 0x440 | 0x0000 0000 |
| OTGFS_HCCHAR0   | 0x500 | 0x0000 0000 |
| OTGFS_HCINT0    | 0x508 | 0x0000 0000 |
| OTGFS_HCINTMSK0 | 0x50C | 0x0000 0000 |
| OTGFS_HCTSIZ0   | 0x510 | 0x0000 0000 |
| OTGFS_HCCHAR1   | 0x520 | 0x0000 0000 |
| OTGFS_HCINT1    | 0x528 | 0x0000 0000 |
| OTGFS_HCINTMSK1 | 0x52C | 0x0000 0000 |
| OTGFS_HCTSIZ1   | 0x530 | 0x0000 0000 |
| OTGFS_HCCHAR2   | 0x540 | 0x0000 0000 |
| OTGFS_HCINT2    | 0x548 | 0x0000 0000 |
| OTGFS_HCINTMSK2 | 0x54C | 0x0000 0000 |
| OTGFS_HCTSIZ2   | 0x550 | 0x0000 0000 |
| OTGFS_HCCHAR3   | 0x560 | 0x0000 0000 |
| OTGFS_HCINT3    | 0x568 | 0x0000 0000 |
| OTGFS_HCINTMSK3 | 0x56C | 0x0000 0000 |
| OTGFS_HCTSIZ3   | 0x570 | 0x0000 0000 |
| OTGFS_HCCHAR4   | 0x580 | 0x0000 0000 |
| OTGFS_HCINT4    | 0x588 | 0x0000 0000 |
| OTGFS_HCINTMSK4 | 0x58C | 0x0000 0000 |
| OTGFS_HCTSIZ4   | 0x590 | 0x0000 0000 |
| OTGFS_HCCHAR5   | 0x5A0 | 0x0000 0000 |
| OTGFS_HCINT5    | 0x5A8 | 0x0000 0000 |
| OTGFS_HCINTMSK5 | 0x5AC | 0x0000 0000 |
| OTGFS_HCTSIZ5   | 0x5B0 | 0x0000 0000 |
| OTGFS_HCCHAR6   | 0x5C0 | 0x0000 0000 |
| OTGFS_HCINT6    | 0x5C8 | 0x0000 0000 |
| OTGFS_HCINTMSK6 | 0x5CC | 0x0000 0000 |
| OTGFS_HCTSIZ6   | 0x5D0 | 0x0000 0000 |
| OTGFS_HCCHAR7   | 0x5E0 | 0x0000 0000 |
| OTGFS_HCINT7    | 0x5E8 | 0x0000 0000 |
| OTGFS_HCINTMSK7 | 0x5EC | 0x0000 0000 |
| OTGFS_HCTSIZ7   | 0x5F0 | 0x0000 0000 |
| OTGFS_HCCHAR8   | 0x600 | 0x0000 0000 |
| OTGFS_HCINT8    | 0x608 | 0x0000 0000 |
| OTGFS_HCINTMSK8 | 0x60C | 0x0000 0000 |
| OTGFS_HCTSIZ8   | 0x610 | 0x0000 0000 |
| OTGFS_HCCHAR9   | 0x620 | 0x0000 0000 |

|                  |       |             |
|------------------|-------|-------------|
| OTGFS_HCINT9     | 0x628 | 0x0000 0000 |
| OTGFS_HCINTMSK9  | 0x62C | 0x0000 0000 |
| OTGFS_HCTSIZ9    | 0x630 | 0x0000 0000 |
| OTGFS_HCCHAR10   | 0x640 | 0x0000 0000 |
| OTGFS_HCINT10    | 0x648 | 0x0000 0000 |
| OTGFS_HCINTMSK10 | 0x64C | 0x0000 0000 |
| OTGFS_HCTSIZ10   | 0x650 | 0x0000 0000 |
| OTGFS_HCCHAR11   | 0x660 | 0x0000 0000 |
| OTGFS_HCINT11    | 0x668 | 0x0000 0000 |
| OTGFS_HCINTMSK11 | 0x66C | 0x0000 0000 |
| OTGFS_HCTSIZ11   | 0x670 | 0x0000 0000 |
| OTGFS_HCCHAR12   | 0x680 | 0x0000 0000 |
| OTGFS_HCINT12    | 0x688 | 0x0000 0000 |
| OTGFS_HCINTMSK12 | 0x68C | 0x0000 0000 |
| OTGFS_HCTSIZ12   | 0x690 | 0x0000 0000 |
| OTGFS_HCCHAR13   | 0x6A0 | 0x0000 0000 |
| OTGFS_HCINT13    | 0x6A8 | 0x0000 0000 |
| OTGFS_HCINTMSK13 | 0x6AC | 0x0000 0000 |
| OTGFS_HCTSIZ13   | 0x6B0 | 0x0000 0000 |
| OTGFS_HCCHAR14   | 0x6C0 | 0x0000 0000 |
| OTGFS_HCINT14    | 0x6C8 | 0x0000 0000 |
| OTGFS_HCINTMSK14 | 0x6CC | 0x0000 0000 |
| OTGFS_HCTSIZ14   | 0x6D0 | 0x0000 0000 |
| OTGFS_HCCHAR15   | 0x6E0 | 0x0000 0000 |
| OTGFS_HCINT15    | 0x6E8 | 0x0000 0000 |
| OTGFS_HCINTMSK15 | 0x6EC | 0x0000 0000 |
| OTGFS_HCTSIZ15   | 0x6F0 | 0x0000 0000 |
| OTGFS_DCFG       | 0x800 | 0x0820 0000 |
| OTGFS_DCTL       | 0x804 | 0x0000 0002 |
| OTGFS_DSTS       | 0x808 | 0x0000 0010 |
| OTGFS_DIEPMSK    | 0x810 | 0x0000 0000 |
| OTGFS_DOEPMSK    | 0x814 | 0x0000 0000 |
| OTGFS_DAINT      | 0x818 | 0x0000 0000 |
| OTGFS_DAINTMSK   | 0x81C | 0x0000 0000 |
| OTGFS_DIEPEMPMSK | 0x834 | 0x0000 0000 |
| OTGFS_DIEPCTL0   | 0x900 | 0x0000 0000 |
| OTGFS_DIEPINT0   | 0x908 | 0x0000 0080 |
| OTGFS_DIEPTSIZ0  | 0x910 | 0x0000 0000 |
| OTGFS_DTXFSTS0   | 0x918 | 0x0000 0200 |
| OTGFS_DIEPCTL1   | 0x920 | 0x0000 0000 |
| OTGFS_DIEPINT1   | 0x928 | 0x0000 0080 |

|                |       |             |
|----------------|-------|-------------|
| OTGFS_DIEPTSI1 | 0x930 | 0x0000 0000 |
| OTGFS_DTXFSTS1 | 0x938 | 0x0000 0200 |
| OTGFS_DIEPCTL2 | 0x940 | 0x0000 0000 |
| OTGFS_DIEPINT2 | 0x948 | 0x0000 0080 |
| OTGFS_DIEPTSI2 | 0x950 | 0x0000 0000 |
| OTGFS_DTXFSTS2 | 0x958 | 0x0000 0200 |
| OTGFS_DIEPCTL3 | 0x960 | 0x0000 0000 |
| OTGFS_DIEPINT3 | 0x968 | 0x0000 0080 |
| OTGFS_DIEPTSI3 | 0x970 | 0x0000 0000 |
| OTGFS_DTXFSTS3 | 0x978 | 0x0000 0200 |
| OTGFS_DIEPCTL4 | 0x980 | 0x0000 0000 |
| OTGFS_DIEPINT4 | 0x988 | 0x0000 0080 |
| OTGFS_DIEPTSI4 | 0x990 | 0x0000 0000 |
| OTGFS_DTXFSTS4 | 0x998 | 0x0000 0200 |
| OTGFS_DIEPCTL5 | 0x9A0 | 0x0000 0000 |
| OTGFS_DIEPINT5 | 0x9A8 | 0x0000 0080 |
| OTGFS_DIEPTSI5 | 0x9B0 | 0x0000 0000 |
| OTGFS_DTXFSTS5 | 0x9B8 | 0x0000 0200 |
| OTGFS_DIEPCTL6 | 0x9C0 | 0x0000 0000 |
| OTGFS_DIEPINT6 | 0x9C8 | 0x0000 0080 |
| OTGFS_DIEPTSI6 | 0x9D0 | 0x0000 0000 |
| OTGFS_DTXFSTS6 | 0x9D8 | 0x0000 0200 |
| OTGFS_DIEPCTL7 | 0x9E0 | 0x0000 0000 |
| OTGFS_DIEPINT7 | 0x9E8 | 0x0000 0080 |
| OTGFS_DIEPTSI7 | 0x9F0 | 0x0000 0000 |
| OTGFS_DTXFSTS7 | 0x9F8 | 0x0000 0200 |
| OTGFS_DOEPCTL0 | 0xB00 | 0x0000 8000 |
| OTGFS_DOEPINT0 | 0xB08 | 0x0000 0000 |
| OTGFS_DOEPTSI0 | 0xB10 | 0x0000 0000 |
| OTGFS_DOEPCTL1 | 0xB20 | 0x0000 0000 |
| OTGFS_DOEPINT1 | 0xB28 | 0x0000 0000 |
| OTGFS_DOEPTSI1 | 0xB30 | 0x0000 0000 |
| OTGFS_DOEPCTL2 | 0xB40 | 0x0000 0000 |
| OTGFS_DOEPINT2 | 0xB48 | 0x0000 0000 |
| OTGFS_DOEPTSI2 | 0xB50 | 0x0000 0000 |
| OTGFS_DOEPCTL3 | 0xB60 | 0x0000 0000 |
| OTGFS_DOEPINT3 | 0xB68 | 0x0000 0000 |
| OTGFS_DOEPTSI3 | 0xB70 | 0x0000 0000 |
| OTGFS_DOEPCTL4 | 0xB80 | 0x0000 0000 |
| OTGFS_DOEPINT4 | 0xB88 | 0x0000 0000 |
| OTGFS_DOEPTSI4 | 0xB90 | 0x0000 0000 |

|                 |       |             |
|-----------------|-------|-------------|
| OTGFS_DOEPCTL5  | 0xBA0 | 0x0000 0000 |
| OTGFS_DOEPINT5  | 0xBA8 | 0x0000 0000 |
| OTGFS_DOEPTSIZ5 | 0xBB0 | 0x0000 0000 |
| OTGFS_DOEPCTL6  | 0xBC0 | 0x0000 0000 |
| OTGFS_DOEPINT6  | 0xBC8 | 0x0000 0000 |
| OTGFS_DOEPTSIZ6 | 0xBD0 | 0x0000 0000 |
| OTGFS_DOEPCTL7  | 0xBE0 | 0x0000 0000 |
| OTGFS_DOEPINT7  | 0xBE8 | 0x0000 0000 |
| OTGFS_DOEPTSIZ7 | 0xBF0 | 0x0000 0000 |
| OTGFS_PCGCCTL   | 0xE00 | 0x0000 0000 |

### 21.6.3 OTGFS global registers

These registers are available in both host and device modes, and do not need to be reprogrammed when switching between two modes.

#### 21.6.3.1 OTGFS status and control register (OTGFS\_GOTGCTL)

This register controls the OTG function and reflects its status.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                          |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                           |
| Bit 21     | CURMOD   | 0x0         | ro   | Current Mode of Operation<br>Accessible in both host and device modes<br>This bit indicates the current operation mode.<br>0: Device mode<br>1: Host mode                                            |
| Bit 20: 17 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                           |
| Bit 16     | CONIDSTS | 0x1         | ro   | Accessible in both host and device modes<br>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 its default value.                                                                                                                                                                           |

#### 21.6.3.2 OTGFS interrupt status control register (OTGFS\_GOTGINT)

The application reads this register to know about which kind of OTG interrupt is generated, and writes this register to clear the OTG interrupt.

| Bit       | Name      | Reset value | Type | Description                                                                                                                                                                                                                       |
|-----------|-----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved  | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                        |
| Bit 2     | SESENDDET | 0x0         | rw1c | Available in both host and device modes<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 its default value.                                                                                                                                                                                                        |

#### 21.6.3.3 OTGFS AHB configuration register (OTGFS\_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   | 0x0000000   | resd | Kept at its default value.                                                                                                                                     |
| Bit 8     | PTXFEMPLVL | 0x0         | rw   | Accessible in host mode only<br>Periodic TxFIFO empty level<br>It indicates when the periodic TxFIFO empty interrupt bit in the GINTSTS register is triggered. |

|          |             |      |      |                                                                                                                                                                                                                                                                                                                  |
|----------|-------------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |             |      |      | 0: PTXFEMP (GINTSTS) interrupt indicates that the periodic TxFIFO is half empty<br>1: PTXFEMP (GINTSTS) interrupt indicates that the periodic TxFIFO is fully empty                                                                                                                                              |
|          |             |      |      | Accessible in both host mode and device modes<br>Non-Periodic TxFIFO empty level<br>In host mode, this bit indicates when the non-periodic TxFIFO empty interrupt (NPTXFEMP in GINTSTS) is triggered.                                                                                                            |
| Bit 7    | NPTXFEMPLVL | 0x0  | rw   | In device mode, this bit indicates when the IN endpoint TxFIFO empty interrupt (TXFEMP bit in DIEPINTn) is triggered.<br>0: The TXFEMP (in DIEPINTn) interrupt indicates that the IN endpoint TxFIFO is half empty<br>1: The TXFEMP (in DIEPINTn) interrupt indicates that the IN endpoint TxFIFO is fully empty |
| Bit 6: 1 | Reserved    | 0x00 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                       |
| Bit 0    | GLBINTMSK   | 0x0  | rw   | Accessible in both host mode and device modes<br>Global interrupt mask<br>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 USB configuration register (OTGFS\_GUSBCFG)

This register is used to configure the controller after power-on or a change between host mode and 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 modes<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 modes<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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 14     | Reserved  | 0x0         | resd | Kept at its 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: 3 | Reserved | 0x08 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 2: 0 | TOUTCAL  | 0x0  | rw   | <p>Accessible in both host mode and device modes</p> <p>FS Timeout calibration</p> <p>The number of PHY clocks that the application programs in these bits is added to the full-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. The application must program these bits based on the enumeration speed. The number of bit times added per PHY clock is 0.25 bit times.</p> |

### 21.6.3.5 OTGFS reset register (OTGFS\_GRSTCTL)

The application resets various hardware modules in the controller through this register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | AHBIDLE  | 0x1         | ro   | <p>Accessible in both host mode and device modes</p> <p>AHB master Idle</p> <p>This bit indicates that the AHB master state machine is in idle condition.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 30: 11 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 10: 6  | TXFNUM   | 0x00        | rw   | <p>Accessible in both host mode and device modes</p> <p>TxFIFO number</p> <p>This field indicates the FIFO number that must be refreshed through the TxFIFO Flush bit. Do not make changes to this field until the controller clears the TxFIFO Flush bit.</p> <p>00000:</p> <ul style="list-style-type: none"> <li>- Non-periodic TxFIFO in host mode</li> <li>- Tx FIFO 0 in device mode</li> </ul> <p>00001:</p> <ul style="list-style-type: none"> <li>- Periodic TxFIFO in host mode</li> <li>- TXFIFO 1 in device mode</li> </ul> <p>00010:</p> <ul style="list-style-type: none"> <li>- TXFIFO 2 in device mode</li> </ul> <p>...</p> <p>01111:</p> <ul style="list-style-type: none"> <li>- TXFIFO 15 in device mode</li> </ul> <p>10000:</p> <ul style="list-style-type: none"> <li>- Refresh all the transmit FIFOs in device or host mode</li> </ul>                                                                                                                     |
| Bit 5      | TXFFLSH  | 0x0         | rw1s | <p>Accessible in both host mode and device modes</p> <p>TxFIFO Flush</p> <p>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.</p> <p>The application must write this bit only after checking that the controller is neither writing to nor reading from the TxFIFO.</p> <p>Verify using these registers:</p> <p>Read: NAK effective interrupt (NAK Effective Interrupt) ensures that the controller is not reading from the FIFO</p> <p>Write: AHBIDLE bit in GRSTCTL ensures that the controller is not writing to the FIFO.</p> <p>For FIFO reprogramming, it is usually recommended to carry out flushing operation.</p> <p>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)</p> |
| Bit 4      | RXFFLSH  | 0x0         | rw1s | Accessible in both host mode and device modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|       |           |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     |      | 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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 2 | FRMCNTRST | 0x0 | rw1s | Accessible in both host mode and device modes<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 modes<br>PIU FS dedicated controller soft reset<br>This bit is used to reset PIU full-speed dedicated controller 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 modes<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).<br>Additionally, the application must ensure that the bit 31 in this register is set (AHB master is in idle state) before performing other operations.<br>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 interrupt register (OTGFS\_GINTSTS)

This register interrupts the application due to system-level events in the current mode (device or host mode), as shown in Figure 21-2.

Some of the bits in this register are valid 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 modes<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 its 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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 26     | PTXFEMP                  | 0x1         | ro   | Accessible in host mode only<br>Periodic TxFIFO 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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 21     | INCOMPIP<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 its 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.                                                                                                                                                                                                                                                                        |
| Bit 13     | ENUMDONE    | 0x0 | rw1c | Accessible in device mode only<br>Enumeration done<br>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 its 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 modes<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 modes<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>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>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 modes<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 modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|       |        |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|--------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     |    | 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 interrupt mask register (OTGFS\_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 its 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 its 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 its 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 its default value.                                                                                                                      |
| Bit 16     | Reserved                       | 0x0         | resd | Kept at its 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                                                                                                                  |

|          |               |     |      |                                                                             |
|----------|---------------|-----|------|-----------------------------------------------------------------------------|
|          |               |     |      | 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 its 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    | NPTXFEMPPMSK  | 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 its default value.                                                  |

### 21.6.3.8 OTGFS receive status debug read/OTG status read and POP registers (OTGFS\_GRXSTSR / OTGFS\_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 its 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<br>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 its 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. |

|            |        |       |    |                                                                                                                                                                                                                                                                                                                                   |
|------------|--------|-------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        |       |    | 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 20: 17 | PKTSTS | 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 16: 15 | DPID   | 0x0   | ro | Byte count<br>Indicates the byte count of the received data packet.                                                                                                                                                                                                                                                               |
| Bit 14: 4  | BCNT   | 0x000 | ro | Endpoint number<br>Indicates the endpoint number to which the currently received data packet belongs.                                                                                                                                                                                                                             |
| Bit 3: 0   | EPTNUM | 0x0   | ro |                                                                                                                                                                                                                                                                                                                                   |

### 21.6.3.9 OTGFS receive FIFO size register (OTGFS\_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 its 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<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 non-periodic Tx FIFO size

#### (OTGFS\_GNPTXFSIZ)/Endpoint 0 Tx FIFO size registers (OTGFS\_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 256              |
| Bit 15: 0  | NPTXFSTADDR | 0x0200      | ro/rw | Non-periodic transmit SRAM start address<br>This field contains the memory start address of the Non-periodic Transmit FIFO SRAM. |

Device:

| Bit        | Name           | 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>Minimum value is 16<br>Maximum value is 256                   |
| 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 non-periodic Tx FIFO size/request queue status register (OTGFS\_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 Tx FIFO 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 Tx FIFO space available<br>Indicates the amount of space available in the non-periodic Tx FIFO. 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 general controller configuration register (OTGFS\_GCCFG)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                             |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                              |
| 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 its default value.                                                                                                                                                                                                                                                                              |
| Bit 17     | LP_MODE  | 0x0         | rw   | Low-power mode<br>This bit is used to control the OTG PHY consumption. 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                                                                                                                                                                                |

|           |          |        |      |                                                                                          |
|-----------|----------|--------|------|------------------------------------------------------------------------------------------|
| Bit 15: 0 | Reserved | 0x0000 | resd | Kept at its default value.                                                               |
|           |          |        |      | USB communication.<br>0: Power down enable<br>1: Power down disable (Transceiver active) |

### 21.6.3.13 OTGFS controller ID register (OTGFS\_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 host periodic Tx FIFO size register (OTGFS\_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                                                              |
| 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 device IN endpoint Tx FIFO size register (OTGFS\_DIEPTXF<sub>n</sub>) (x=1...7, 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<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 host mode configuration register (OTGFS\_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: FS/LS, depending on the largest speed supported by the connected device. |

|          |             |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|-------------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 1: 0 | FSLSPCLKSEL | 0x0 | rw | 1: FS/LS-only, even if the connected device supports high-speed.<br>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: Reserved<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.2OTGFS host frame interval register (OTGFS\_HFIR)

This register is used to program the current

| 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   | Frame interval<br>The application uses this field to program the interval between two consecutive SOFs (full speed)<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.<br>1 ms * (FS/LS PHY clock frequency) |

#### 21.6.4.3OTGFS host frame number/frame time remaining register (OTGFS\_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   | Frame time remaining<br>Indicates the time remaining in the current frame (FS/HS), 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. |
| Bit 15: 0  | FRNUM | 0x3FFF      | ro   | 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.                                                                                                                                                                         |

#### 21.6.4.4 OTGFS host periodic Tx FIFO/request queue register (OTGFS\_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   | 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.<br>Bit [31]: Odd/Even frame<br>0: Transmit in even frame<br>1: Transmit in odd frame<br>Bit [30: 27]: Channel/Endpoint number<br>Bit [26: 25]: Type<br>00: IN/OUT<br>01: Zero-length packet<br>10: Reserved<br>11: Channel command disable<br>Bit [24]: Terminate (last request for the selected channel or endpoint) |
| Bit 23: 16 | PTXQSPCAVAIL | 0x08        | ro   | 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.<br>00: Periodic transmit request queue is full<br>01: 1 space available<br>10: 2 space available<br>N: n space available ( $0 \leq n \leq 8$ )<br>Others: Reserved                                                                                                                              |
| 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 \leq n \leq 512$ )<br>Others: Reserved                                                                                                                                                                |

#### 21.6.4.5 OTGFS host all channels interrupt register (OTGFS\_HAIT)

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 21-2. There is one interrupt bit for each channel, up to 16 bits. 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  | HAIINT   | 0x0000      | ro   | Channel interrupts<br>One bit per channel: bit 0 for channel 0, bit 15 for channel 15. |

#### 21.6.4.6 OTGFS host all channels interrupt mask register (OTGFS\_HAINTMSK)

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 its default value.                                                                 |
| Bit 15: 0  | HAINTMSK | 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 host port control and status register (OTGFS\_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 shown in Figure 21-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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 18: 17 | PRTSPD    | 0x0         | ro   | Port speed<br>Indicates the speed of the device connected to this port.<br>00: Reserved<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     | PRTPWR    | 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<br>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 its 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 | PTOVRCCHNG | 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 | 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 ro by the application.<br>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.<br>0: Port disabled<br>1: Port enabled                                                                                                                                                                                                                 |
| Bit 1 | PRTCONDET  | 0x0 | rw1c | 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.                                                                                                                                                                                                                                                                                                                                                        |
| Bit 0 | PRTCONSTS  | 0x0 | ro   | Port connect status<br>0: No device is connected to the port<br>1: A device is connected to the port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 21.6.4.8OTGFS host channelx characteristics register (OTGFS\_HCCHARx) (x = 0...15, where x= channel number)

| Bit    | Name  | Reset value | Type | Description                                                                                                                       |
|--------|-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31 | CHENA | 0x0         | rw1s | Channel enable<br>This bit is set by the application and cleared by the OTG host.<br>0: Channel disabled<br>1: Channel enabled    |
| Bit 30 | CHDIS | 0x0         | rw1s | 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.                                                                                                                                                                                               |
| 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 its default value.                                                                                                                                                                                                                                                                                                                      |
| Bit 15     | EPTDIR   | 0x0   | rw   | <p>Endpoint direction<br/>Indicates whether the transfer is in IN or OUT.<br/>0: OUT<br/>1: IN</p>                                                                                                                                                                                                                                              |
| Bit 14: 11 | EPTNUM   | 0x0   | rw   | <p>Endpoint number<br/>Indicates the endpoint number on the device (serving as data source or receiver)</p>                                                                                                                                                                                                                                     |
| Bit 10: 0  | MPS      | 0x000 | rw   | <p>Maximum packet size<br/>Indicates the maximum packet size of the corresponding port.</p>                                                                                                                                                                                                                                                     |

#### 21.6.4.9 OTGFS host channelx interrupt register (OTGFS\_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 21-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 of 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 its default value.                                                                                               |
| Bit 10     | DTGLERR  | 0x0         | rw1c | <p>Data toggle error<br/>This bit can only be set by the controller. The application must write 1 to clear this bit.</p> |
| Bit 9      | FRMOVRUN | 0x0         | rw1c | <p>Frame overrun<br/>This bit can only be set by the controller. The application must write 1 to clear this bit.</p>     |
| Bit 8      | BBLERR   | 0x0         | rw1c | <p>Babble error<br/>This bit can only be set by the controller. The application must write 1 to clear this bit.</p>      |
| Bit 7      | XACTERR  | 0x0         | rw1c | <p>Transaction error<br/>Indicates one of the following errors occurred on the USB</p>                                   |

|       |          |     |      |                                                                                                                                                                        |
|-------|----------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 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 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                             |
| 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 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                             |
| 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.10 OTGFS host channelx interrupt mask register (OTGFS\_HCINTMSKx) (x = 0...15, 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 its 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      | Reserved    | 0x0         | resd | Kept at its default value.                       |
| Bit 1      | CHHLTDMSK   | 0x0         | rw   | Channel halted mask                              |
| Bit 0      | XFERCMSK    | 0x0         | rw   | Transfer completed mask                          |

#### 21.6.4.11 OTGFS host channelx transfer size register (OTGFS\_HCTSIZx) (x = 0...15, where x= channel number)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                     |
| 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.                                                                                                                                                                                                                |
|           |          |         |    | Transfer size<br>For an OUT transfer, this field indicates the number of data bytes the host sends during a transfer.                                                                                                                                      |
| Bit 18: 0 | XFERSIZE | 0x00000 | rw | 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.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 device configure register (OTGFS\_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     | 0x04100     | resd | Kept at its 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 its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 2      | NZSTSOUTHSHK | 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: Reserved<br>01: Reserved<br>10: Reserved<br>11: Full speed (USB1.1 transceiver, clock is 48MHz)                                                                                        |

### 21.6.5.2 OTGFS device control register (OTGFS\_DCTL)

| Bit        | Name       | Reset value | Type | Description                                                                                                                                             |
|------------|------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved   | 0x00000     | resd | Kept at its default value.                                                                                                                              |
| Bit 11     | PWROPRGDNE | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|          |             |     |    | Set global OUT NAK<br>Writing to this bit sets the global OUT NAK.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 9    | SGOUTNAK    | 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 8    | CGNPINNAK   | 0x0 | wo | Set global Non-periodic IN NAK<br>Writing to this bit sets the global Non-periodic OUT NAK.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          |             |     |    | 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 7    | SGNPINNAK   | 0x0 | wo | 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 6: 4 | TSTCTL      | 0x0 | rw | 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 3    | GOUTNAKSTS  | 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 2    | GNPINNAKSTS | 0x0 | ro | 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 1    | SFTDISCON   | 0x1 | 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.                                                                                                                                                                                                            |
| Bit 0    | RWKUPSIG    | 0x0 | rw |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 21-5 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-5 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<br>(performing transfers) | 2.5us            |

### 21.6.5.3 OTGFS device status register (OTGFS\_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 its 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>01: Reserved<br>10: Reserved<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:<br>When there is an activity on the USB bus<br>When the application writes to the remote wakeup signal bit in the device control register. |

### 21.6.5.4 OTGFS device OTGFSIN endpoint common interrupt mask register (OTGFS\_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: 10 | Reserved     | 0x000000    | resd | Kept at its 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 its 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<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 | Reserved       | 0x0 | resd | Kept at its default value.                                                                          |
| 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 device OUT endpoint common interrupt mask register (OTGFS\_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:10 | Reserved    | 0x000000    | resd | Kept at its 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 its default value.                                                                                  |
| Bit 6     | B2BSETUPMSK | 0x0         | rw   | Back-to-back SETUP packets received mask<br>0: Interrupt masked<br>1: Interrupt unmasked                    |
| Bit 5     | Reserved    | 0x0         | resd | Kept at its default value.                                                                                  |
| 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     | Reserved    | 0x0         | resd | Kept at its default value.                                                                                  |
| 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.6OTGFS device all endpoints interrupt mask register (OTGFS\_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 its 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 its 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.7OTGFS all endpoints interrupt mask register (OTGFS\_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 its 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 its 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.8OTGFS device IN endpoint FIFO empty interrupt mask register (OTGFS\_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 its 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.9OTGFS device control IN endpoint 0 control register (OTGFS\_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: |

|            |          |        |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |        |      | 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 its 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 its 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 | 0x1    | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 15     | USBACEPT | 0x0    | 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 its 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.10 OTGFS device IN endpoint-x control register (OTGFS\_DIEPCTLx) (x=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<br/>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:<br/>SETUP stage done<br/>Endpoint disabled<br/>Transfer completed</p>                                                                                                                                              |
| Bit 30     | EPTDIS                 | 0x0         | rw1s | <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> |
| Bit 29     | SETD1PID/<br>SETODDFR  | 0x0         | wo   | <p>Set DATA1 PID<br/>Applies to interrupt/bulk IN endpoints only. Writing to this bit sets the endpoint data PID bit in this register to DATA1.<br/>Set odd frame<br/>Applies to synchronous IN endpoints only. Writing to this bit sets the Even/Odd frame to odd frame.<br/>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 IN endpoints only. Writing to this bit sets the endpoint data PID bit in this register to DATA0.<br/>Set Even frame<br/>Applies to synchronous IN endpoints only. Writing to this bit sets the Even/Odd frame to even frame.<br/>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.<br/>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 this endpoint.<br/>0: Not clear NAK<br/>1: Clear NAK</p>                                                                                                                                                                                                                                                                                                      |
| Bit 25: 22 | TXFNUM                 | 0x0         | rw   | <p>TxFIFO number<br/>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<br/>Applies to non-control, non-synchronous IN and OUT endpoints.<br/>The application sets this bit to stall all tokens from the 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.</p>                                          |

|            |                  |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|------------------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                  |       |      | 0: Stall all invalid tokens<br>1: Stall all valid tokens                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 20     | Reserved         | 0x0   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 19: 18 | EPTYPE           | 0x0   | rw   | <p>Endpoint type<br/>This is the transfer type supported by this logical endpoint.</p> <p>00: Control<br/>01: Synchronous<br/>10: Bulk<br/>11: Interrupt</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 17     | NAKSTS           | 0x0   | ro   | <p>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), 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.</p> |
| Bit 16     | DPID/<br>EOFRNUM | 0x0   | ro   | <p>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.</p> <p>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.</p> <p>0: Even frame<br/>1: Odd frame</p> |
| Bit 15     | USBACEPT         | 0x0   | rw   | <p>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.</p> <p>0: Inactive<br/>1: Active</p>                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 14: 11 | Reserved         | 0x0   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 10: 0  | MPS              | 0x000 | rw   | <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 21.6.5.11 OTGFS device control OUT endpoint 0 control register (OTGFS\_DOEPCCTL0)

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 its 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 its 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 followings:<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 its 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 its 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<br>10: 16 bytes<br>11: 8 bytes                                                                                                                                                                                                                                                                               |

### 21.6.5.12 OTGFS device control OUT endpoint-x control register (OTGFS\_DOEPCCTLx) (x= 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</p> <p>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</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> <p>0: No effect<br/>1: Endpoint disabled</p> |
| Bit 29     | SETD1PID/<br>SETODDFR  | 0x0         | rw   | <p>Set DATA1 PID</p> <p>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</p> <p>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</p> <p>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</p> <p>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</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 the endpoint.</p> <p>0: Not clear NAK<br/>1: Clear NAK</p>                                                                                                                                                                                                                                                                                                                                                    |
| Bit 25: 22 | Reserved               | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 21     | STALL                  | 0x0         | rw   | <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-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</p>                                                                                                                                                  |

|            |                  |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|------------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |                  |       |      | 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 followings:<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 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 its 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.13 OTGFS 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-2 When the IEPINT bit of the OTGFS\_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\_DAINT and OTGFS\_GINTST registers.

| Bit       | Name        | Reset value | Type | Description                                                                                                                                                                                                                                             |
|-----------|-------------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved    | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                              |
| Bit 7     | TXFEMP      | 0x1         | 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.                                           |
| Bit 5     | Reserved    | 0x0         | resd | 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 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     | Reserved    | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                              |
| 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.14 OTGFS device OUT endpoint-x interrupt register (OTGFS\_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-2. When the OEPINT bit of the OTGFS\_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\_DAINT and OTGFS\_GINTST registers.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x00000000  | resd | Kept at its 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     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                 |
| 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. |

|       |          |     |      |                                                                                                                                                                                                                                                                                                           |
|-------|----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |      | 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 3 | SETUP    | 0x0 | rw1c |                                                                                                                                                                                                                                                                                                           |
| Bit 2 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                |
| 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.15 OTGFS device IN endpoint 0 transfer size register (OTGFS\_DIEPTSIZ0)

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 its 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 its default value.                                                                                                                                                                                                                                                                                                                                                       |
| Bit 6: 0   | XFERSIZE | 0x00        | rw   | Transfer size<br>Indicates the transfer size (in bytes) for the endpoint 0. 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.16 OTGFS device OUT endpoint 0 transfer size register (OTGFS\_DOEPTSIZ0)

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 its 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 its 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 its default value.                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 6: 0   | XFERSIZE | 0x00        | rw   | Transfer size<br>Indicates the transfer size (in bytes) for the endpoint 0. 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. |

The controller decrements this field every time a packet from the receive FIFO is written to the external memory.

### 21.6.5.17 OTGFS device IN endpoint-x transfer size register (OTGFS\_DIEPTSIZx) (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 its 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.18 OTGFS device IN endpoint transmit FIFO status register (OTGFS\_DTXFSTSx) (x=1...7, where x is endpoint number)

This is a read-only register containing the free space information for the device IN endpoint transmit FIFO.

| Bit        | Name       | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                       |
|------------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved   | 0x0000      | resd | Kept at its 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.19 OTGFS device OUT endpoint-x transfer size register (OTGFS\_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 its default value.                                                                                                                                                                                                                                         |
|            |          |             |      | Received data PID                                                                                                                                                                                                                                                  |
|            |          |             |      | Applies to synchronous OUT endpoints only.                                                                                                                                                                                                                         |
|            |          |             |      | This is the data PID received in the last packet.                                                                                                                                                                                                                  |
|            |          |             |      | 00: DATA0                                                                                                                                                                                                                                                          |
|            |          |             |      | 01: DATA2                                                                                                                                                                                                                                                          |
|            |          |             |      | 10: DATA1                                                                                                                                                                                                                                                          |
|            |          |             |      | 11: MDATA                                                                                                                                                                                                                                                          |
| Bit 30: 29 | RXDPID   | 0x0         | ro   | SETUP packet count                                                                                                                                                                                                                                                 |
|            |          |             |      | Applies to synchronous OUT endpoints only. Indicates the number of back-to-back SETUP data packets the endpoint can receive.                                                                                                                                       |
|            |          |             |      | 01: 1 packet                                                                                                                                                                                                                                                       |
|            |          |             |      | 10: 2 packets                                                                                                                                                                                                                                                      |
|            |          |             |      | 11: 3 packets                                                                                                                                                                                                                                                      |
| Bit 28: 19 | PKTCNT   | 0x000       | rw   | Packet count                                                                                                                                                                                                                                                       |
|            |          |             |      | Indicates the number of USB packets transmitted on the endpoint.                                                                                                                                                                                                   |
|            |          |             |      | This field is decremented every time a packet is written to the receive FIFO (maximum packet size and short packet)                                                                                                                                                |
| Bit 18: 0  | XFERSIZE | 0x00000     | rw   | Transfer size                                                                                                                                                                                                                                                      |
|            |          |             |      | 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. |
|            |          |             |      | The controller decrements this field every time a packet is read from the receive FIFO and written to the external memory.                                                                                                                                         |

## 21.6.6 Power and clock control registers

### 21.6.6.1 OTGFS power and clock gating control register (OTGFS\_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                                                                                                                                                                                               |
|           |          |             |      | Indicates that the PHY has been suspended.                                                                                                                                                                |
| Bit 3: 1  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                |
| Bit 0     | STOPPCLK | 0x0         | rw   | Stop PHY clock                                                                                                                                                                                            |
|           |          |             |      | 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

HICK auto clock calibration (HICK ACC), which uses the SOF signal (1 ms of period) generated as a reference signal, implements the sampling and calibration for 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 flags
  - Reference signal lost error flag
- Two interrupt source flag
  - Calibration ready flag
  - Reference signal lost error flag
- Two calibration modes: coarse calibration and fine 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 25-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 as a reference signal, implements the sampling and calibration for 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.

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 bit in the CRM module. This signal is used to calibrate the HICK in bypass mode. The value is defined by the HICKCAL[7: 0] in the CRM\_CTRL register.
  - CRM\_HICKTRIM: the HICKTRIM bit in the CRM module. This signal is used to calibrate the HICK in bypass mode. The 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 when the CRM\_HICKTRIM value changes. In other words, the HICK output frequency will increase by 20kHz each time the CRM\_HICKTRIM value is decremented by one; the HICK output frequency will reduce by 20kHz each time the CRM\_HICKTRIM value is incremented by one.
- USB\_SOF: USB Start-of-Frame signal given by the USB device. Its high-level width is 12 system clock cycles, a pulse signal of 1 ms.
  - HICKCLK: HICK clock. The original HICK output 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 after frequency division (1/6), the HICK clock frequency will change by 40KHz (design value) each time the HICKCAL changes, which is positively correlated. 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 after frequency division (1/6), the HICK clock frequency will change by 20KHz (design value) each time the HICKCAL changes, which is positively correlated.

Refer to Section 22.6 for more information about the bit definition in the registers.

Figure 22-2 ACC block diagram



## 22.5 Principle

USB\_SOF period signal: 1ms of period must be accurate, which is a prerequisite of 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 accuracy 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 HICKTRIM according to the specified step as soon as the condition for triggering auto calibration is reached.

#### Cross:

If the auto calibration condition is met, the actual sampling data in 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 HICKTRIM 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 start decrease either the HICKCAL or HICKTRIM 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 HICKTRIM.

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 as soon as 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 HICKTRIM will not be able to 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: 2 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 1     | RSLOST   | 0x0         | ro   | <p>Reference Signal Lost<br/>0: Reference Signal is not lost<br/>1: Reference Signal is lost</p> <p>Note: During the calibration, 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.</p> |
| Bit 0     | CALRDY   | 0x0         | ro   | <p>Internal high-speed clock calibration ready<br/>0: Internal 8MHz oscillator calibration is not ready<br/>1: Internal 8MHz oscillator calibration is ready</p> <p>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.</p>                                                                                                                                                                                                           |

## 22.6.3 Control register 1 (ACC\_CTRL1)

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved  | 0x00000     | resd | Forced by hardware to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 11: 8  | STEP      | 0x1         | rw   | <p>Calibrated step<br/>This field defines the value after each calibration.</p> <p>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.</p> <p>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.</p> |
| Bit 7: 6   | Reserved  | 0x0         | rw   | Forced by hardware to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 5      | CALRDYIEN | 0x0         | rw   | CALRDY interrupt enable<br>This bit is set or cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|       |          |     |    |                                                                                                                                                                                                                                                                                                                                                     |
|-------|----------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     |    | 0: Interrupt generation disabled<br>1: ACC interrupt is generated when CALRDY=1 in the ACC_STS register                                                                                                                                                                                                                                             |
| Bit 4 | EIEN     | 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 3 | Reserved | 0x0 | rw | Forced by hardware to 0                                                                                                                                                                                                                                                                                                                             |
| Bit 2 | SOFSEL   | 0x0 | rw | SOF select<br>This bit is set or cleared by software.<br>0: USB1 as SOF signal source<br>1: USB2 as SOF signal source                                                                                                                                                                                                                               |
| Bit 1 | ENTRIM   | 0x0 | rw | 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 0 | CALON    | 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. |

## 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 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_HICKTRIM 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. 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<br>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).                                                                                  |
| Bit 15: 0  | C2       | 0x1F40      | rw   | 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<br>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. |
| Bit 15: 0  | C3       | 0x1F54      | rw   | 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 Infrared timer (IRTMR)

The IRTMR (Infrared Timer) is used to generate the IR\_OUT signal that drives the infrared LED so as to achieve infrared control.

The IR\_OUT signals consists of a low-frequency modulation envelope and high-frequency carrier signals. The low-frequency modulation envelope signal comes from 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 via PB9 or PA13 (multiplexed mode needs to be configured in advance).

Figure 23-1 IRTMR block diagram



# 24 External memory controller (XMC)

## 24.1 XMC introduction

XMC peripheral block can translate the AHB signals into the external memory signals and vice versa. It boasts two chip-select signals for interfacing up to external memories at a time. The supported external memories include a NAND Flash and a static memory device featuring multiplexed signals or additional address latch function. Such static memory device includes a static random memory (SRAM), NOR Flash and PSRAM.

## 24.2 XMC main features

NOR/PSRAM has the following features:

- Chip-select signal supports 4 external memories, each of which has their own control register
- Support access to static memory devices, including
  - Static random access memory (SRAM)
  - NOR Flash
  - PSRAM
- 8-bit or 16-bit wide memory
- Various timing mode selection
  - Two modes with the same timings for read and write
  - Four modes with different timings for read and write
  - Multiplexed address/data mode
  - Synchronous mode
- Programmable timing control registers
- Translate the AHB data size into the appropriate external memory data size

NAND has the following features:

- Chip-select signal supports 2 external memories
- 8-bit or 16-bit wide NAND Flash
- Two storage spaces with programmable timing control registers
- Translate the AHB data size into the appropriate external memory data size
- Support ECC calculation

PC card has the following features:

- Chip-select signal supports 1 external memory
- 16-bit wide PC card
- Three storage spaces with programmable timing control registers
- Translate the AHB data size into the appropriate external memory data size

SDRAM card has the following features:

- Connected to 2 independent SDRAM devices externally
- 8-bit or 16-bit wide SDRAM data bus
- Supports up to 13-bit address row, 11-bit address column and 4 internal memory areas (4x16Mx16bit :128 MB and 4x16Mx8bit: 64 MB)
- SDRAM clock sources: HCLK/2, HCLK/3 or HCLK/4
- Supports AHB byte, halfword and word accesses
- Programmable SDRAM access timing parameters
- Automatic row and memory boundary management

- Multi-memory area ping-pong access
- Automatic refresh operation of software-programmable refresh rate
- Supports self-refresh mode
- Supports power-down mode
- SDRAM power-on initialization through software
- CAS latency can be configured 1/2/3 SDRAM clock cycles
- Cacheable Read FIFO with 6x 32-bit depth

## 24.3 XMC architecture

### 24.3.1 Block diagram

Figure 24-1 XMC block diagram



While interfacing to the external memory, NOR/PSRAM, NAND, PC card and SDRAM uses different pins respectively, as shown in Table 24-1, Table 24-2 and Table 24-3.

Table 24-1 NOR/PSRAM pins

| Pin name         | I/O    | Description                                |
|------------------|--------|--------------------------------------------|
| XMC_CLK          | Output | Clock                                      |
| XMC_NE[x], x=1,4 | Output | Chip select                                |
| XMC_NADV         | Output | Address latch or address valid (NL) signal |

|                   |                         |                                   |
|-------------------|-------------------------|-----------------------------------|
| XMC_A[x]          | Output                  | Address bus                       |
| XMC_NOE           | Output                  | Output enable signal              |
| XMC_NWE           | Output                  | Write enable signal               |
| XMC_LB and XMC_UB | Output                  | Byte select signal                |
| XMC_D[15: 0]      | Read input/write output | Data bus/multiplexed address data |
| XMC_NWAIT         | Input                   | Wait signal                       |

Table 24-2 NAND pins

| Pin name     | I/O                     | Description                |
|--------------|-------------------------|----------------------------|
| XMC_NCE[2]   | Output                  | Chip select                |
| XMC_A[17]    | Output                  | Address latch (ALE) signal |
| XMC_A[16]    | Output                  | Command latch (CLE) signal |
| XMC_NOE      | Output                  | Output enable (NRE) signal |
| XMC_NWE      | Output                  | Write enable signal        |
| XMC_D[15: 0] | Read input/write output | Data bus                   |
| XMC_NWAIT    | Input                   | Ready/Busy (R/B)           |

Table 24-3 PC card pins

| Pin name     | I/O                     | Description                                                  |
|--------------|-------------------------|--------------------------------------------------------------|
| XMC_NCE4_1   | Output                  | Chip select 1 (CE1)                                          |
| XMC_NCE4_2   | Output                  | Chip select 2 (CE2)                                          |
| XMC_A[10:0]  | Output                  | Address bus                                                  |
| XMC_NOE      | Output                  | Output enable signal for general-purpose space and attribute |
| XMC_NWE      | Output                  | Write enable signal for general-purpose space                |
| XMC_NIORD    | Output                  | Output enable signal for IO space                            |
| XMC_NIOWR    | Output                  | Write enable signal for IO space                             |
| XMC_NREG     | Output                  | Attribute space select signal                                |
| XMC_D[15: 0] | Read input/write output | Data bus                                                     |
| XMC_CD       | Input                   | PC card detection signal, active high                        |
| XMC_NWAIT    | Input                   | Ready/Busy (R/B)                                             |
| XMC_INTR     | Input                   | PC card interrupt signal                                     |

Table 24-4 SDRAM pins

| Pin name       | I/O                     | Description          |
|----------------|-------------------------|----------------------|
| XMC_SDCKE0     | Output                  | DEVICE0 clock enable |
| XMC_SDCKE1     | Output                  | DEVICE1 clock enable |
| XMC_SDSCS0     | Output                  | DEVICE0 chip-select  |
| XMC_SDSCS1     | Output                  | DEVICE1 chip-select  |
| XMC_SDCLK      | Output                  | Clock signal         |
| XMC_SDNRAS     | Output                  | Row select           |
| XMC_SDNCAS     | Output                  | Column select        |
| XMC_SDNWE      | Output                  | Write enable         |
| XMC_LB, XMC_UB | Output                  | Byte select          |
| XMC_A[12:0]    | Output                  | Address bus          |
| XMC_A[14]      | Output                  | BANK address low     |
| XMC_A[15]      | Output                  | B BANK address high  |
| XMC_D[15:0]    | Read input/write output | Data bus             |

### 24.3.2 Address mapping

XMC address is divided into multiple memory banks, as shown below.

Figure 24-2 XMC memory banks

| Address    | Memory banks                        | Memory chip select signals |
|------------|-------------------------------------|----------------------------|
| 6000 0000h | NOR/PSRAM bank1 64 MB               | XMC_NE[1]                  |
| 63FF FFFFh |                                     |                            |
| 6400 0000h | NOR/PSRAM bank2 64 MB               | XMC_NE[2]                  |
| 67FF FFFFh |                                     |                            |
| 6800 0000h | NOR/PSRAM bank3 64 MB               | XMC_NE[3]                  |
| 6BFF FFFFh |                                     |                            |
| 6C00 0000h | NOR/PSRAM bank4 64 MB               | XMC_NE[4]                  |
| 6FFF FFFFh |                                     |                            |
| 7000 0000h | NAND bank2<br>regular memory 128 MB | XMC_NCE[2]                 |
| 77FF FFFFh |                                     |                            |
| 7800 0000h | NAND bank2<br>special memory 128 MB |                            |
| 7EFF FFFFh |                                     |                            |
| 8000 0000h | NAND bank3<br>regular memory 128 MB | XMC_NCE[3]                 |
| 87FF FFFFh |                                     |                            |
| 8800 0000h | NAND bank3<br>special memory 128 MB |                            |
| 8EFF FFFFh |                                     |                            |
| A800 0000h | PC card<br>common memory 32 MB      |                            |
| A9FF FFFFh |                                     |                            |
| AC00 0000h | PC card<br>attribute memory 32 MB   | XMC_NCE4_1<br>XMC_NCE4_2   |
| ADFF FFFFh |                                     |                            |
| AE00 0000h | PC card<br>I/O memory 32 MB         |                            |
| AEFF FFFFh |                                     |                            |
| C000 0000h | SDRAM bank0<br>128 MB               | XMC_SDCS0                  |
| CZEE FFFFh |                                     |                            |
| D000 0000h | SDRAM bank1<br>128 MB               | XMC_SDCS1                  |
| DZEE FFFFh |                                     |                            |

Some HADDR bits are used to select which bank to access to, as shown in Table 24-3.

Table 24-5 Memory bank selection

| HADDR[31: 28]     | HADDR[27: 26]                                                                                                                                                                            |  |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                   | 00: bank1<br>01: bank2<br>10: bank3<br>11: bank4                                                                                                                                         |  |  |  |
| 0110: NOR/PSRAM   |                                                                                                                                                                                          |  |  |  |
| 0111: NAND bank2  | HADDR[27]<br>0: Regular space<br>1: Special space                                                                                                                                        |  |  |  |
| 1000: NAND bank3  | HADDR[17: 16]<br>00: Data area<br>01: Command area<br>1x: Address area<br>00: Data area<br>01: Command area<br>1x: Address area<br>00: Data area<br>01: Command area<br>1x: Address area |  |  |  |
| 1010: PC card     | HADDR[28]<br>00: General-purpose memory space<br>10: Attribute memory space<br>11: I/O space                                                                                             |  |  |  |
| 1100: SDRAM BANK1 | HADDR[28]<br>HADDR[26: 0]                                                                                                                                                                |  |  |  |
| 1101: SDRAM BANK2 | BANK and row/column address mapping<br>HADDR[28]<br>HADDR[26: 0]                                                                                                                         |  |  |  |

Table 24-6 8-bit SDRAM address mapping

| Row size | HADDR (AHB internal address line) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |    |   |   |   |   |   |   |   |   |   |
|----------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------|----|----|---|---|---|---|---|---|---|---|---|
|          | 27                                | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12                                | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| 11-bit   | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[10:0] Column[7:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[10:0] Column[8:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[10:0] Column[9:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[10:0] Column[10:0] |    |    |   |   |   |   |   |   |   |   |   |
| 12-bit   | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[11:0] Column[7:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[11:0] Column[8:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[11:0] Column[9:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[11:0] Column[10:0] |    |    |   |   |   |   |   |   |   |   |   |
| 13-bit   | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[12:0] Column[7:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[12:0] Column[8:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[12:0] Column[9:0]  |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bank [1:0] Row[12:0] Column[10:0] |    |    |   |   |   |   |   |   |   |   |   |

Table 24-7 16-bit SDRAM address mapping

| Row size | HADDR (AHB address line) |               |    |           |    |    |    |    |    |    |    |    |    |              |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----------|--------------------------|---------------|----|-----------|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|---|---|---|---|---|---|---|---|---|
|          | 27                       | 26            | 25 | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14           | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| 11-bit   | Reserved                 | Bank [1:0]    |    | Row[10:0] |    |    |    |    |    |    |    |    |    | Column[7:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                 | Bank [1:0]    |    | Row[10:0] |    |    |    |    |    |    |    |    |    | Column[8:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                 | Bank [1:0]    |    | Row[10:0] |    |    |    |    |    |    |    |    |    | Column[9:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                 | Bank [1:0]    |    | Row[10:0] |    |    |    |    |    |    |    |    |    | Column[10:0] |    |    |    |    |   |   |   |   |   |   |   |   |   |
| 12-bit   | Reserved                 | Bank [1:0]    |    | Row[11:0] |    |    |    |    |    |    |    |    |    | Column[7:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                 | Bank [1:0]    |    | Row[11:0] |    |    |    |    |    |    |    |    |    | Column[8:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                 | Bank [1:0]    |    | Row[11:0] |    |    |    |    |    |    |    |    |    | Column[9:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reser                    | Bank [1:0]    |    | Row[11:0] |    |    |    |    |    |    |    |    |    | Column[10:0] |    |    |    |    |   |   |   |   |   |   |   |   |   |
| 13-bit   | Reserved                 | Bank [1:0]    |    | Row[12:0] |    |    |    |    |    |    |    |    |    | Column[7:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reserved                 | Bank [1:0]    |    | Row[12:0] |    |    |    |    |    |    |    |    |    | Column[8:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Reser                    | Bank [1:0]    |    | Row[12:0] |    |    |    |    |    |    |    |    |    | Column[9:0]  |    |    |    |    |   |   |   |   |   |   |   |   |   |
|          | Re                       | Bank s. [1:0] |    | Row[12:0] |    |    |    |    |    |    |    |    |    | Column[10:0] |    |    |    |    |   |   |   |   |   |   |   |   |   |

## 24.4 NOR/PSRAM

NOR/PSRAM offers multiple access modes with different timings to drive multiple memories including NOR Flash, SRAM, PSRAM and Cellular RAM.

There are two banks, bank 1 and bank, with independent control registers. Such two banks can be accessed by means of different timings and different chip-select signals.

### 24.4.1 Operating mode

#### Pin function:

Pin signals vary from external memory to external memory. Table 24-8 lists typical pin signals.

Table 24-8 Pin signals for NOR and PSRAM

| XMC pin name           | NOR Flash                                                     | PSRAM                                                         |
|------------------------|---------------------------------------------------------------|---------------------------------------------------------------|
| XMC_CLK                | Clock (synchronous mode)                                      | Clock (synchronous mode)                                      |
| XMC_NE[x]              | Chip-select                                                   | Chip-select                                                   |
| XMC_NADV               | Address latch or address valid                                | Address latch or address valid                                |
| XMC_A[23:16], XMC_A[0] | Address bus                                                   | Address bus                                                   |
| XMC_NOE                | Output enable                                                 | Output enable                                                 |
| XMC_NWE                | Write enable                                                  | Write enable                                                  |
| XMC_LB, XMC_UB         | Without using XMC_LB, XMC_UB                                  | XMC_LB: lower byte<br>XMC_UB: upper byte                      |
|                        | Data bus                                                      | Data bus                                                      |
| XMC_D[15: 0]           | multiplexed address data bus (multiplex and synchronous mode) | multiplexed address data bus (multiplex and synchronous mode) |
| XMC_NWAIT              | NOR Flash wait request                                        | PSRAM wait request                                            |

Note: If the memory data size is 8-bit, the typical data bus is XMC\_D[7: 0].

#### Access address

The upper bytes of the HADDR bit is used to select a memory bank while the lower bytes to data memory address. HADDR is a byte address whereas the XMC supports the memory addressed in words or half words. Address translation between them is shown in Table 22-5. As long as read/write access to a specific address occurs, the XMC will enable chip-select signals and write/read operation to the external memories according to the HADDR bit.

Table 24-9 Address translation between HADDR and external memory

| External memory data width | Address connection                                                                                                                                             | Accessible space (bits)    | maximum memory |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------|
| 8-bit                      | HADDR[25: 0] is linked to XMC_A[25: 0].<br>In multiplexed and synchronous mode,<br>HADDR[15: 0] is connected to XMC_D[15: 0]<br>during address latch period.   | 64 Mbyte x8 =512 Mbit      |                |
| 16-bit                     | HADDR[26: 1] is connected to XMC_A[25: 0].<br>In multiplexed and synchronous mode,<br>HADDR[16: 1] is connected to XMC_D[15: 0]<br>during address latch period | (64 Mbyte x 16)/2=512 Mbit |                |

**Data access**

In case that the AHB data width is not equal to that of the memories, the XMC will make appropriate arrangement according to the typical signals of the external memories. Table 22-6 lists the operation modes supported by XMC.

Table 24-10 Data access width vs. external memory data width

| Memory    | Mode                    | AHB data width | Memory width | Description                                           |
|-----------|-------------------------|----------------|--------------|-------------------------------------------------------|
| SRAM      | Asynchronous read/write | 8/16/32        | 8            | One-time access, or split into 2 or 4 accesses        |
|           | Asynchronous read/write | 8/16/32        | 16           | XMC_LB and XMC_UB, One-time, or split into two access |
| NOR Flash | Asynchronous read       | 8              | 16           |                                                       |
|           | Asynchronous read/write | 16             | 16           |                                                       |
|           | Asynchronous read/write | 32             | 16           | Split into 2 XMC accesses                             |
|           | Synchronous read        | 16             | 16           |                                                       |
|           | Synchronous read        | 32             | 16           | Split into 2 XMC accesses                             |
|           | Asynchronous read       | 8              | 16           |                                                       |
| PSRAM     | Asynchronous write      | 8              | 16           | Use XMC_LB and XMC_UB                                 |
|           | Asynchronous read/write | 16             | 16           |                                                       |
|           | Asynchronous read/write | 32             | 16           | Split into 2 XMC accesses                             |
|           | Synchronous write       | 8              | 16           | Use XMC_LB and XMC_UB                                 |
|           | Synchronous read/write  | 16             | 16           |                                                       |
|           | Synchronous read/write  | 32             | 16           | Split into 2 XMC accesses                             |

**24.4.2 Access mode**

The XMC offers various access modes. Each access mode is operated based on the timing parameters, as shown in Table 24-11. Users can perform programming operations according to the specifications of the external memory and application needs.

Access modes available in the XMC:

- Read/write operation with the same timings: Mode 1 and Mode 2
- Read/write operation with different timings: Mode A, B, C and D
- Multiplexed address data lines
- Clock-based synchronous mode

Table 24-11 NOR/PSRAM parameter registers

| Parameter register | Function            | Access mode                      | Unit          |
|--------------------|---------------------|----------------------------------|---------------|
| ADDRST             | Address set-up time | 1, 2, A, B, C, D and multiplexed | HCLK cycle    |
| ADDRHT             | Address-hold time   | D and multiplexed                | HCLK cycle    |
| DTST               | Data set-up time    | 1, 2, A, B, C, D and multiplexed | HCLK cycle    |
| DTLAT              | Data latency time   | Synchronous                      | XMC_CLK cycle |
| CLKPSC             | Clock prescaler     | Synchronous                      | HCLK cycle    |

In addition to timing parameter registers for timing control, if the wait enable bit (NWASEN or NWSEN) is enabled, the XMC will start to check whether the XMC\_NWAIT signal is in wait request state during data set time. If so, the XMC will wait until the XMC\_NWAIT returns to the ready state before data transfer.

#### 24.4.2.1 Read/write operation with the same timings

The timing of read and write operation in mode 1 and mode 2 is based on the XMC\_BK1TMG register configuration.

##### Mode 1

As configured in Table 24-12 and Table 24-13, the XMC uses mode 1 to access the external memory. The timing of read operation is shown in Figure 24-3. The timing of write operation is shown in Figure 24-4.

Table 24-12 Mode 1— SRAM/NOR Flash chip select control register (XMC\_BK1CTRL) configuration

| Bit        | Description                                   | Configuration                                                                    |
|------------|-----------------------------------------------|----------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                                                              |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                                                              |
| Bit 18: 16 | CRPGS: CRAM page size                         | 0x0                                                                              |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications                                     |
| Bit 14     | RWTD: Read-write timing different             | 0x0                                                                              |
| Bit 13     | NWSEN: NWAIT in synchronous transfer enable   | 0x0                                                                              |
| Bit 12     | WEN: Write enable                             | Configure according to needs                                                     |
| Bit 11     | NWTCFG: NWAIT timing configuration            | 0x0                                                                              |
| Bit 10     | WRAPEN: Wrapped enable                        | 0x0                                                                              |
| Bit 9      | NWPOL: NWAIT polarity                         | Configure according to memory specifications                                     |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x0                                                                              |
| Bit 7      | Reserved                                      | 0x1                                                                              |
| Bit 6      | NOREN: NOR flash access enable                | 0x0                                                                              |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications                                     |
| Bit 3: 2   | DEV: Memory device type                       | Configure according to memory specifications. It is valid except 0x2 (NOR Flash) |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | 0x0                                                                              |
| Bit 0      | EN: Memory bank enable                        | 0x1                                                                              |

Table 24-13 Mode 1— SRAM/NOR Flash chip select timing register (XMC\_BK1TMG) configuration

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x0                                                                                                                               |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-3</a> and <a href="#">Figure 24-4</a> . Configure according to needs and memory specifications.    |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-3</a> and <a href="#">Figure 24-4</a> . Configure according to needs and memory specifications.    |

Figure 24-3 NOR/PSRAM mode 1 read access



Figure 24-4 NOR/PSRAM mode 1 write access



## Mode 2

As configured in Table 24-14 and Table 24-15, the XMC uses mode 2 to access the external memory. The timing of read operation is shown in Figure 24-5. The timing of write operation is shown in Figure 24-6.

Table 24-14 Mode 2 — SRAM/NOR Flash chip select control register

| Bit        | Description                                   | Configuration                                 |
|------------|-----------------------------------------------|-----------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                           |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                           |
| Bit 18: 16 | CRPGS:CRAM page size                          | 0x0                                           |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications. |
| Bit 14     | RWTD: Read-write timing different             | 0x0                                           |

|          |                                             |                                               |
|----------|---------------------------------------------|-----------------------------------------------|
| Bit 13   | NWSEN: NWAIT in synchronous transfer enable | 0x0                                           |
| Bit 12   | WEN: Write enable                           | Configure according to needs.                 |
| Bit 11   | NWTCFG: NWAIT timing configuration          | 0x0                                           |
| Bit 10   | WRAPEN: Wrapped enable                      | 0x0                                           |
| Bit 9    | NWPOL: NWAIT polarity                       | Configure according to memory specifications. |
| Bit 8    | SYNCBEN: Synchronous burst enable           | 0x0                                           |
| Bit 7    | Reserved                                    | 0x1                                           |
| Bit 6    | NOREN: NOR Flash access enable              | 0x1                                           |
| Bit 5: 4 | EXTMDBW: External memory data bus width     | Configure according to memory specifications. |
| Bit 3: 2 | DEV: Memory device type                     | 0x2 (NOR Flash)                               |
| Bit 1    | ADMUXEN: Address/data multiplexing enable   | 0x0                                           |
| Bit 0    | EN: Memory bank enable                      | 0x1                                           |

Table 24-15 Mode 2 — SRAM/NOR Flash chip select timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x0                                                                                                                               |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-5</a> and <a href="#">Figure 24-6</a> . Configure according to needs and memory specifications.    |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-5</a> and <a href="#">Figure 24-6</a> . Configure according to needs and memory specifications.    |

Figure 24-5 NOR/PSRAM mode 2 read access



Figure 24-6 NOR/PSRAM mode 2 write access



#### 24.4.2.2 Read/write operation with different timings

The timing of read operation in mode A/B/C/D is based on the SRAM/NOR Flash chip select timing register (XMC\_BK1TMG). The timing of write operation is based on SRAM/NOR Flash write timing register (XMC\_BK1TMGWR). In addition to this, it is possible to mix A, B, C and D modes for read and write operations.

##### Mode A

As configured in Table 24-16 and Table 24-17, the XMC uses mode A to access the external memory. The timing of read operation is shown in Figure 24-7. The timing of write operation is shown in Figure 24-8.

Table 24-16 Mode A—SRAM/NOR Flash chip select control register

| Bit        | Description                                   | Configuration                                                                    |
|------------|-----------------------------------------------|----------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                                                              |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                                                              |
| Bit 18: 16 | CRPGS:CRAM page size                          | 0x0                                                                              |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications.                                    |
| Bit 14     | RWTD: Read-write timing different             | 0x1                                                                              |
| Bit 13     | NWSEN: NWAIT in synchronous transfer enable   | 0x0                                                                              |
| Bit 12     | WEN: Write enable                             | Configure according to needs.                                                    |
| Bit 11     | NWTCFG: NWAIT timing configuration            | 0x0                                                                              |
| Bit 10     | WRAPEN: Wrapped enable                        | 0x0                                                                              |
| Bit 9      | NWPOL: NWAIT polarity                         | Configure according to memory specifications.                                    |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x0                                                                              |
| Bit 7      | Reserved                                      | 0x1                                                                              |
| Bit 6      | NOREN: NOR Flash access enable                | 0x0                                                                              |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications.                                    |
| Bit 3: 2   | DEV: Memory device type                       | Configure according to memory specifications. It is valid except 0x2 (NOR Flash) |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | 0x0                                                                              |
| Bit 0      | EN: Memory bank enable                        | 0x1                                                                              |

Table 24-17 Mode A—SRAM/NOR Flash chip select timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x0 (Mode A)                                                                                                                      |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-7</a> . Configure according to needs and memory specifications.                                    |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-7</a> . Configure according to needs and memory specifications.                                    |

Table 24-18 Mode A—SRAM/NOR Flash write timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x0 (Mode A)                                                                                                                      |
| Bit 27: 20 | Reserved                   | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-8</a> . Configure according to needs and memory specifications.                                    |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-8</a> . Configure according to needs and memory specifications.                                    |

Figure 24-7 NOR/PSRAM mode A read access



Figure 24-8 NOR/PSRAM mode A write access

**Mode B**

As configured in Table 24-19, Table 24-20, and Table 24-21, the XMC uses mode B to access the external memory. The timing of read operation is shown in Figure 24-9. The timing of write operation is shown in Figure 24-10.

Table 24-19 Mode B—SRAM/NOR Flash chip select register

| Bit        | Description                                   | Configuration                                 |
|------------|-----------------------------------------------|-----------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                           |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                           |
| Bit 18: 16 | CRPGS:CRAM page size                          | 0x0                                           |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications. |
| Bit 14     | RWTD: Read-write timing different             | 0x1                                           |
| Bit 13     | NWSN: NWAIT in synchronous transfer enable    | 0x0                                           |
| Bit 12     | WEN: Write enable                             | Configure according to needs.                 |
| Bit 11     | NWTCFG: NWAIT timing configuration            | 0x0                                           |
| Bit 10     | WRAPEN: Wrapped enable                        | 0x0                                           |
| Bit 9      | NWPOL: NWAIT polarity                         | Configure according to memory specifications. |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x0                                           |
| Bit 7      | Reserved                                      | 0x1                                           |
| Bit 6      | NOREN: NOR Flash access enable                | 0x1                                           |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications. |
| Bit 3: 2   | DEV: Memory device type                       | 0x2 (NOR Flash)                               |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | 0x0                                           |
| Bit 0      | EN: Memory bank enable                        | 0x1                                           |

Table 24-20 Mode B—SRAM/NOR Flash chip select timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x1 (Mode B)                                                                                                                      |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-9</a> . Configure according to needs and memory specifications.                                    |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-9</a> . Configure according to needs and memory specifications.                                    |

Table 24-21 Mode B—SRAM/NOR Flash write timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x1 (Mode B)                                                                                                                      |
| Bit 27: 20 | Reserved                   | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-10</a> . Configure according to needs and memory specifications.                                   |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-10</a> . Configure according to needs and memory specifications.                                   |

Figure 24-9 NOR/PSRAM mode B read access



Figure 24-10 NOR/PSRAM mode B write access

**Mode C**

As configured in Table 24-22, Table 24-23 and Table 24-24, the XMC uses mode C to access the external memory. The timing of read operation is shown in Figure 24-11. The timing of write operation is shown in Figure 24-12.

Table 24-22 Mode C—SRAM/NOR Flash chip select register

| Bit        | Description                                   | Configuration                                 |
|------------|-----------------------------------------------|-----------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                           |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                           |
| Bit 18: 16 | CRPGS:CRAM page size                          | 0x0                                           |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications. |
| Bit 14     | RWTD: Read-write timing different             | 0x1                                           |
| Bit 13     | NWSEN: NWAIT in synchronous transfer enable   | 0x0                                           |
| Bit 12     | WEN: Write enable                             | Configure according to needs.                 |
| Bit 11     | NWTCFG: NWAIT timing configuration            | 0x0                                           |
| Bit 10     | WRAPEN: Wrapped enable                        | 0x0                                           |
| Bit 9      | NWPOL: NWAIT polarity                         | Configure according to memory specifications. |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x0                                           |
| Bit 7      | Reserved                                      | 0x1                                           |
| Bit 6      | NOREN: NOR Flash access enable                | 0x1                                           |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications. |
| Bit 3: 2   | DEV: Memory device type                       | 0x2 (NOR Flash)                               |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | 0x0                                           |
| Bit 0      | EN: Memory bank enable                        | 0x1                                           |

Table 24-23 Mode C—SRAM/NOR Flash chip select timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x2 (Mode C)                                                                                                                      |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-11</a> . Configure according to needs and memory specifications.                                   |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-11</a> . Configure according to needs and memory specifications.                                   |

Table 24-24 Mode C— SRAM/NOR Flash write timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x1 (Mode C)                                                                                                                      |
| Bit 27: 20 | Reserved                   | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-12</a> . Configure according to needs and memory specifications.                                   |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-12</a> . Configure according to needs and memory specifications.                                   |

Figure 24-11 NOR/PSRAM mode C read access



Figure 24-12 NOR/PSRAM mode C write access

**Mode D**

As configured in Table 24-25, Table 24-26, and Table 24-27, the XMC uses mode D to access the external memory. The timing of read operation is shown in Figure 24-13. The timing of write operation is shown in Figure 24-14.

Table 24-25 Mode D—SRAM/NOR Flash chip select register (XMC\_BK1CTRL) configuration

| Bit        | Description                                   | Configuration                                 |
|------------|-----------------------------------------------|-----------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                           |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                           |
| Bit 18: 16 | CRPGS:CRAM page size                          | 0x0                                           |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications. |
| Bit 14     | RWTD: Read-write timing different             | 0x1                                           |
| Bit 13     | NWSEN: NWAIT in synchronous transfer enable   | 0x0                                           |
| Bit 12     | WEN: Write enable                             | Configure according to needs.                 |
| Bit 11     | NWTCFG: NWAIT timing configuration            | 0x0                                           |
| Bit 10     | WRAPEN: Wrapped enable                        | 0x0                                           |
| Bit 9      | NWPOL: NWAIT polarity                         | Configure according to memory specifications. |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x0                                           |
| Bit 7      | Reserved                                      | 0x1                                           |
| Bit 6      | NOREN: NOR Flash access enable                | Configure according to memory specifications. |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications. |
| Bit 3: 2   | DEV: Memory device type                       | Configure according to memory specifications. |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | 0x0                                           |
| Bit 0      | EN: Memory bank enable                        | 0x1                                           |

Table 24-26 Mode D—SRAM/NOR Flash chip select timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x3 (Mode D)                                                                                                                      |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-13</a> . Configure according to needs and memory specifications.                                   |
| Bit 7: 4   | ADDRHT: Address-hold time  | Refer to <a href="#">Figure 24-13</a> . Configure according to needs and memory specifications.                                   |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-13</a> . Configure according to needs and memory specifications.                                   |

Table 24-27 Mode D— SRAM/NOR Flash write timing register

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x3 (Mode D)                                                                                                                      |
| Bit 27: 20 | Reserved                   | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-14</a> . Configure according to needs and memory specifications.                                   |
| Bit 7: 4   | ADDRHT: Address-hold time  | Refer to <a href="#">Figure 24-14</a> . Configure according to needs and memory specifications.                                   |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-14</a> . Configure according to needs and memory specifications.                                   |

Figure 24-13 NOR/PSRAM mode D read access



Figure 24-14 NOR/PSRAM mode D write access



#### 24.4.2.3 Multiplexed mode

As configured in Table 24-28 and Table 24-29, the XMC uses mode A to access the external memory. The timing of read operation is shown in Figure 24-15. The timing of write operation is shown in Figure 24-16.

Table 24-28 Multiplexed mode — SRAM/NOR Flash chip select control register

| Bit        | Description                                   | Configuration                                                               |
|------------|-----------------------------------------------|-----------------------------------------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                                                         |
| Bit 19     | MWMC: Memory write mode control               | 0x0                                                                         |
| Bit 18: 16 | CRPGS:CRAM page size                          | 0x0                                                                         |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | Configure according to memory specifications.                               |
| Bit 14     | RWTD: Read-write timing different             | 0x0                                                                         |
| Bit 13     | NWSEN: NWAIT in synchronous transfer enable   | 0x0                                                                         |
| Bit 12     | WEN: Write enable                             | Configure according to needs.                                               |
| Bit 11     | NWTCFG: NWAIT timing configuration            | 0x0                                                                         |
| Bit 10     | WRAPEN: Wrapped enable                        | 0x0                                                                         |
| Bit 9      | NWPOL: NWAIT polarity                         | Configure according to memory specifications.                               |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x0                                                                         |
| Bit 7      | Reserved                                      | 0x1                                                                         |
| Bit 6      | NOREN: NOR Flash access enable                | Configure according to memory specifications.                               |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications.                               |
| Bit 3: 2   | DEV: Memory device type                       | Configure according to memory specifications. It is valid except 0x0 (SRAM) |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | 0x1                                                                         |
| Bit 0      | EN: Memory bank enable                        | 0x1                                                                         |

Table 24-29 Multiplexed mode—SRAM/NOR Flash chip select timing register (XMC\_BK1TMG) configuration

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x0                                                                                                                               |
| Bit 27: 24 | DTLAT: Data latency        | 0x0                                                                                                                               |
| Bit 23: 20 | CLKPSC: Clock prescale     | 0x0                                                                                                                               |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | Refer to <a href="#">Figure 24-15</a> and <a href="#">Figure 24-16</a> . Configure according to needs and memory specifications.  |
| Bit 7: 4   | ADDRHT: Address-hold time  | Refer to <a href="#">Figure 24-15</a> and <a href="#">Figure 24-16</a> . Configure according to needs and memory specifications.  |
| Bit 3: 0   | ADDRST: Address setup time | Refer to <a href="#">Figure 24-15</a> and <a href="#">Figure 24-16</a> . Configure according to needs and memory specifications.  |

Figure 24-15 NOR/PSRAM multiplexed mode read access



Figure 24-16 NOR/PSRAM multiplexed mode write access



#### 24.4.2.4 Synchronous mode

As configured in Table 24-30 and Table 24-31, the XMC uses synchronous mode to access the external memories.

If the memory inserts XMC\_NWAIT signal between the address latch and data transfer, the XMC will not only wait (DTLAT+1) CLK clock cycles but also have to take into account the XMC\_NWAIT signal. During data transmission, the XMC will, depending on the NWTCFG configuration, select to wait either one cycle after the XMC\_NWAIT signal is active or when the XMC\_NWAIT signal is active.

Figure 24-17 shows the timing for read access, while Figure 24-18 shows the timing for write access. Figure 24-17 and Figure 24-18 are examples of XMC waiting in the next cycle of XMC\_NWAIT signal (NWTCFG=0)

Table 24-30 Synchronous mode — SRAM/NOR Flash chip select control register

| Bit        | Description                                   | Configuration                                                                                                                   |
|------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved                                      | 0x0                                                                                                                             |
| Bit 19     | MWMC: Memory write mode control               | 0x1                                                                                                                             |
| Bit 18: 16 | CRPGS:CRAM page size                          | Configure according to memory specifications.                                                                                   |
| Bit 15     | NWASEN: NWAIT in asynchronous transfer enable | 0x0                                                                                                                             |
| Bit 14     | RWTD: Read-write timing different             | 0x0                                                                                                                             |
| Bit 13     | NWSEN: NWAIT in synchronous transfer enable   | Configure according to memory specifications.                                                                                   |
| Bit 12     | WEN: Write enable                             | Configure according to needs.                                                                                                   |
| Bit 11     | NWTCFG: NWAIT timing configuration            | Configure according to memory specifications.                                                                                   |
| Bit 10     | WRAPEN: Wrapped enable                        | Configure according to needs.                                                                                                   |
| Bit 9      | NWPOL: NWAIT polarity                         | c                                                                                                                               |
| Bit 8      | SYNCBEN: Synchronous burst enable             | 0x1                                                                                                                             |
| Bit 7      | Reserved                                      | 0x1                                                                                                                             |
| Bit 6      | NOREN: NOR Flash access enable                | Write synchronization: 0x0<br>Read synchronization: Configure according to memory specifications.                               |
| Bit 5: 4   | EXTMDBW: External memory data bus width       | Configure according to memory specifications.                                                                                   |
| Bit 3: 2   | DEV: Memory device type                       | Write synchronization: 0x1<br>Read synchronization: Configure according to memory specifications. It is valid except 0x0 (SRAM) |
| Bit 1      | ADMUXEN: Address/data multiplexing enable     | Configure according to needs.                                                                                                   |
| Bit 0      | EN: Memory bank enable                        | 0x1                                                                                                                             |

Table 24-31 Synchronous mode—SRAM/NOR Flash chip select timing register (XMC\_BK1TMG)

| Bit        | Description                | Configuration                                                                                                                     |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved                   | 0x0                                                                                                                               |
| Bit 29: 28 | ASYNCM: Asynchronous mode  | 0x0                                                                                                                               |
| Bit 27: 24 | DTLAT: Data latency        | Refer to Figure 24-17 and Figure 24-18                                                                                            |
| Bit 23: 20 | CLKPSC: Clock prescale     | XMC_CLK cycle is HCLK cycle*(CLKPSC+1). Refer to Figure 24-17 and Figure 24-18                                                    |
| Bit 19: 16 | BUSLAT: Bus latency        | Indicates the time the XMC_NE[x] from the rising edge to the falling edge. Configure according to needs and memory specifications |
| Bit 15: 8  | DTST: Data setup time      | 0x0                                                                                                                               |
| Bit 7: 4   | ADDRHT: Address-hold time  | 0x0                                                                                                                               |
| Bit 3: 0   | ADDRST: Address setup time | 0x0                                                                                                                               |

Figure 24-17 NOR/PSRAM synchronous multiplexed mode read access



Figure 24-18 NOR/PSRAM synchronous multiplexed mode write access



## 24.5 NAND

NAND interface can be used to drive NAND Flash. It is divided into two storage banks: regular bank and special bank, each with its separate timing registers. Both banks can be accessible with different timings.

### 24.5.1 Operating mode

#### Pin function:

Pin signals vary from external memory to external memory. Table 24-32 lists typical pin signals.

Table 24-32 Typical pin signals for NAND Flash

| XMC pin name | 8-bit NAND Flash           | 16-bit NAND Flash                                       |
|--------------|----------------------------|---------------------------------------------------------|
| XMC_NCE[2]   | Chip-select                | Chip-select                                             |
| XMC_A[17]    | Address latch enable (ALE) | Address latch enable (ALE)                              |
| XMC_A[16]    | Command latch enable (CLE) | Command latch enable (CLE)                              |
| XMC_NOE      | Output enable (NRE)        | Output enable (NRE)                                     |
| XMC_NWE      | Write enable               | Write enable                                            |
| XMC_D[15: 0] | Data bus                   | Do not use XMC_D[15: 8]<br>Use XMC_D[7: 0] as data bus. |
| XMC_NWAIT    | Ready/Busy (R/B)           | Ready/Busy (R/B)                                        |

#### Access address

The HADDR is only used to select memory banks. Refer to Table 24-5 for more information.

The user writes the command value in the command section, the destination address in the address section, and reads or writes the data from or to the data section. As the access addresses are transmitted through data bus, the HADDR is actually not associated with NAND Flash size, so theoretically the XMC has no limitation on the NAND Flash capacity accessible.

#### Data access

In case that the AHB data width is not equal to that of the memories, the XMC will make appropriate arrangement according to the typical signals of the external memories. Table 24-33 lists the operation

modes supported by XMC.

Table 24-33 Data access width vs. external memory data width

| Memory      | Mode | AHB data width | Memory width | Description               |
|-------------|------|----------------|--------------|---------------------------|
| 8-bit NAND  | R/W  | 8              | 8            |                           |
|             | R/W  | 16             | 8            | Split into 2 XMC accesses |
|             | R/W  | 32             | 8            | Split into 4 XMC accesses |
| 16-bit NAND | R    | 8              | 16           |                           |
|             | R/W  | 16             | 16           |                           |
|             | R/W  | 32             | 16           | Split into 4 XMC accesses |

## 24.5.2 Access timings

The XMC access the NAND Flash according to the timing parameters, as shown in Table 24-34 and Figure 24-19. Users can perform programming operations according to the specifications of the external memory and application needs.

Table 24-34 NAND parameter registers

| Parameter register | Function                                                           | Access mode | Unit       |
|--------------------|--------------------------------------------------------------------|-------------|------------|
| RGDHIZT/SPDHIZT    | Number of cycles during which the data bus is kept in high-Z state | W           | HCLK cycle |
| RGST/SPST          | Memory set up time                                                 | R/W         | HCLK cycle |
| RGWT/SPWT          | Memory set up time                                                 | R/W         | HCLK cycle |
| RGHT/SPHT          | Memory set up time                                                 | R/W         | HCLK cycle |

Figure 24-19 NAND read access



When the NWEN bit is enabled, the XMC will monitor whether the XMC\_NWAIT signal is pulled low or not at the end of memory hold-up period, if so, it will keep the XMC\_NCE[2] low until the XMC\_NWAIT goes high.

Some NAND Flash devices require that, after receiving the last address byte, that the XMC\_NCE[2] remains low until it enters ready state. This can be done by means of a special timing register and NWEN bits:

The user has to configure the time duration during which the NAND Flash shifts from the rising edge of the XMC\_NWE to the falling edge of the XMC\_NWAIT into a SPHT register, and write the last address byte into a special memory address section so that the XMC can perform write operations based on the timings of the special memory timing register, as shown in Address 3 in Figure 24-20.

Figure 24-20 NAND wait functionality



### 24.5.3 ECC computation

The NAND interface contains ECC computation module so that the data will be used for ECC computation when the NAND interface access the NAND Flash. The computed value is stored into the XMC\_BKxECC register.

To perform an ECC computation:

1. Configure the ECCPGS bit to select the number of bytes to be computed by ECC module: 256, 512, 1024, 2048, 4096 or 8192 bytes.
2. Enable the ECCEN bit.
3. Read/write from and to the data section.
4. After receiving/sending the same number of bytes as the value programmed in the ECCPGS, the XMC will store the ECC computed value into the XMC\_BKxECC registers.
5. Software reads/write the last byte and waits until the FIFO flag is set.
6. Software reads the XMC\_BKxECC register and performs the corresponding error correction routine.
7. Clear the ECCEN bit by software. Repeat from 2 to 6.

The table below lists the ECC result bits corresponding to the number of bytes.

Table 24-35 ECC result bits

| ECCPGS          | 000        | 001        | 010        | 011        | 100        | 101        |
|-----------------|------------|------------|------------|------------|------------|------------|
| Number of bytes | 256        | 512        | 1024       | 2048       | 4096       | 8192       |
| ECC result bits | ECC[21: 0] | ECC[23: 0] | ECC[25: 0] | ECC[27: 0] | ECC[29: 0] | ECC[31: 0] |

### 24.6 PC card

The PC card interface can drive PC cards. They are made of three memory spaces: IO memory space, common memory space and attribute space, each of which has their individual on-chip signal and timing register. The three memory spaces are accessible through different timings.

## 24.6.1 Operating mode

### Pin function:

Pin signals vary from external memory to external memory. Table 24-36 lists typical pin signals.

Table 24-36 Typical pin signals for PC card

| Pin name     | PC card                                       |
|--------------|-----------------------------------------------|
| XMC_NCE4_1   | Chip-select 1 (CE1)                           |
| XMC_NCE4_2   | Chip-select 2 (CE2)                           |
| XMC_A[10:0]  | Address bus                                   |
| XMC_NOE      | Output enable for common and attribute spaces |
| XMC_NWE      | Write enable for common and attribute spaces  |
| XMC_NIORD    | Output enable for IO space                    |
| XMC_NIOWR    | Write enable for IO space                     |
| XMC_NREG     | attribute space select                        |
| XMC_D[15: 0] | Data bus                                      |
| XMC_CD       | PC card detection signal, active high         |
| XMC_NWAIT    | Ready/Busy (R/B)                              |
| XMC_INTR     | PC card interrupt signal                      |

### Access address and Data access

The upper bytes of the HADDR bit is used to select a memory bank while the lower bytes to data memory address. Address translation between them is shown in Table 24-5. As long as read/write access to a specific address occurs, the XMC will enable chip-select signals and write/read operation to the external memories according to the HADDR bit.

In case that the AHB data width is not equal to that of the memories, the XMC will make appropriate arrangement according to the typical signals of the external memories. Table 24-37 lists the operation modes supported by XMC.

Table 24-37 Access data width and PC card data width

| Memory  | Mode       | AHB data size | Memory data size | Description                                                 |
|---------|------------|---------------|------------------|-------------------------------------------------------------|
| PC card | Read/Write | 8             | 16               | Use XMC_NCE4_1                                              |
|         | Read/Write | 16            | 16               | Use XMC_NCE4_1 and XMC_NCE4_2                               |
|         | Read/Write | 32            | 16               | Split into 2 XMC accesses and use XMC_NCE4_1 and XMC_NCE4_2 |

## 24.6.2 Access timings

The XMC access the NAND Flash according to the timing parameters, as shown in Table 24-38 and Figure 24-21. Users can perform programming operations according to the specifications of the external memory and application needs.

Table 24-38 PC card parameter register

| Parameter register     | Description                 | Access mode | Unit        |
|------------------------|-----------------------------|-------------|-------------|
| CMDHIZT/ATDHIZT/IOHIZT | Memory data bus high-Z time | Write       | HCLK cycles |
| CMST/ATST/IOST         | Memory setup time           | Read/Write  | HCLK cycles |
| CMWT/ATWT/IOWT         | Memory wait time            | Read/Write  | HCLK cycles |
| CMHT/ATHT/IOHT         | Memory hold time            | Read/Write  | HCLK cycles |

Figure 24-21 PC card read/write



## 24.7 SDRAM card

### 24.7.1 SDRAM access management

#### SDRAM initialization

The SDRAM initialization sequence defined in the JEDEC specification must be respected before using SDRAM.

The SDRAM initialization is managed by software. To initialize two devices, the BK1 and BK2 bit must be set in the SDRAM\_CMD register. The initialization command is applicable to both devices.

1. Program the SDRAM\_CTRLx register according to the external SDRAM device row/column and bus width and the number of BANK. Read and write operations from/to the SDRAM must be also programmed into the SDRAM\_CTRLx register.
2. Program the memory device timing into the SDRAM\_TMx register. The TRP and TRC timings must be programmed into the SDRAM\_TM1 register.
3. Set CMD=001 to start providing the clock to the memory.
4. Wait for 100us
5. Set CMD=010 to issue a “Precharge All” command.
6. Set CMD=011 and configure the number of consecutive Auto-refresh commands (ART). Typical number is 8.
7. Configure the MRD field (controller supports BL=1 only). Set CMD=100 to issue a “Load Mode Register” command. If the mode registers of these two SDRAM devices are different from each other, this step has to be repeated twice (by setting the BK1 and BK2)
8. Program the refresh counter in the SDRAM\_RCNT register to determine the SDRAM auto-refresh rate.

After the initialization, the SDRAM is ready to accept commands. If a system reset occurs during an ongoing SDRAM access, the SDRAM device has to be reset after re-initialization in order to issue a new access to the SDRAM.

If the “Load Mode Register” and “Self-Refresh” commands are applied to both devices at the same time, access commands are issued using the timing parameters configured for SDRAM device 1.

### SDRAM controller write operation

Before performing any write access, the SDRAM write protection must be disabled by clearing the WRP bit in the SDRAM\_CTRLx register; otherwise, an AHB error may occur.

The SDRAM controller translates single or burst AHB write requests into a single SDRAM write access, which can be done by setting BL=1. In both cases, the SDRAM controller always tries to translate consecutive or discontinuous AHB write requests into a single SDRAM write request in order to increase efficiency.

The SDRAM controller keeps track of the active row for each BANK in order to be able to perform consecutive write accesses to different banks (multibank ping-pong access). If the next write access is in the same row or in another active row, the write operation is performed. If the next write access targets an inactive row, the SDRAM controller generates a precharge command (The BANK where the inactive row is has other open rows, if no other rows, the precharge is unnecessary), and activates the new row and initiates a write operation.

Figure 24-22 SDRAM write access waveforms (Trcd=2, 9 consecutive write access)



### SDRAM controller read operation

The SDRAM controller translates single or burst AHB read requests into a single SDRAM read access, which can be done by setting BL=1.

The SDRAM controller keeps track of the active row for each BANK in order to be able to perform consecutive read accesses to different banks (multibank ping-pong access). If the next read access is in the same row or in another active row, the read operation is performed. If the next read access targets an inactive row, the SDRAM controller generates a precharge command (The BANK where the inactive row is has other open rows, if no other rows, the precharge is unnecessary), and activates the new row and initiates a read operation.

Note: The above-mentioned description applies to the scenario where the SDRAM consecutive read feature is not enabled (that is, read FIFO is unused.)

Figure 24-23 SDRAM read access without using read FIFO (Trcd=2,CL=3, and 4 consecutive read accesses)



When the BSTR is set in the SDRAM\_CTRL1 register, the SDRAM controller continues to send another read command after issuing the current read command. The number of read commands to be issued depends on the CAS latency and RD read delay. The data read in advance during the CAS latency is stored into the read FIFO. Each line of the read FIFO has its address tag. The number of the anticipated read commands (M) is calculated as follows:

$$M = \text{CAS cycles} + \text{RD}/2 + 1$$

For example, CAS=3 and RD= 3xHCLK, then 5 data (not committed) are stored in the FIFO.

Each time a read request occurs, the SDRAM controller will check whether the FIFO address tag matches the address to be read. If matched, take the desired data from the FIFO; if unmatched, issue a read command to the memory, and update FIFO at the same time.

### Row and BANK boundary management

When a read or write access crosses a row boundary, if the next read or write access is sequential and the current access was performed to a row boundary, then the SDRAM controller precharges the currently active row in order to disable the current row, activates a new row, and starts a read/write command to a new row.

If the next access is sequential and the current access crosses BANK boundary, two cases are possible:

- If the current BANK is not the last one, the SDRAM will perform access to the next BANK. If the next BANK is an active row and the active row matches the one to be accessed, a read operation is issued; if such active row is not the one to be accessed, disable the active row and activate a new row; if no active row, activate directly a new row to be accessed, and issue a read/write command.
- If the current BANK is the last memory area, an AHB error occurs.

### SDRAM controller self-refresh operation

The SDRAM device needs an auto-refresh operation. The SDRAM controller periodically issues auto-refresh commands. The refresh rate is defined by the RC value in the SDRAM\_RCNT register. The auto-refresh commands have priority over read/write accesses. In other words, if the auto-refresh commands and read/write access commands are generated simultaneously, the read/write requests are suspended temporarily, and are processed when the auto-refresh is complete.

If the SDRAM has active rows, the SDRAM controller generates all precharge commands before auto-refresh operations.

If a new auto-refresh request occurs while the previous one was not complete, the ERR (Refresh Error) bit is set in the SDRAM\_STS register. An interrupt is generated if the ERIEN has been set.

## 24.7.2 Self-refresh mode and Power-down mode

The SDRAM controller supports two low-power modes: self-refresh mode and power-down mode.

### Self-refresh mode

This mode is selected by setting CMD=101 and by configuring the Target Bank bits (BK1 and/or BK2) in the SDRAM\_CMD register.

The SDRAM clock stops running after a TRAS delay. The internal refresh time stops counting if one of the following conditions is present:

When both SDRAM devices have been initialized, a self-refresh command is issued to both devices; or when one of the devices is not initialized, a self-refresh command is issued to one of the device.

After entering the self-refresh mode, the SDRAM device must remain in this mode for a minimum period of time of TRAS, which is determined by the SDRAM device characteristics. To guarantee this minimum period, the BUSY flag will be set after the self-refresh is entered. The BUSY flag is cleared automatically only after a TRAS time. This bit can be used to judge whether to exit self-refresh mode.

It is possible to leave self-refresh mode by setting CMD=000 or by read/write access to the SDRAM.

### Power-down mode

This mode is selected by setting CMD=110 and by configuring the Target Bank bits (BK1 and/or BK2) in the SDRAM\_CMD register.

During power-down mode, the SDRAM device can also perform auto-refresh operation. When an auto-refresh command occurs, the SDRAM exists from the power-down mode before performing auto-refresh operation. After that, the SDRAM will enter power-down mode again.

It is possible to leave power-down mode by setting CMD=000 or by read/write access to the SDRAM.

## 24.8 XMC registers

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

Table 24-39 XMC register address mapping

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| XMC_BK1CTRL1 | 0x000  | 0x0000 30DB |
| XMC_BK1TMG1  | 0x004  | 0x0FFF FFFF |
| XMC_BK1CTRL2 | 0x008  | 0x0000 30D2 |
| XMC_BK1TMG2  | 0x00C  | 0x0FFF FFFF |
| XMC_BK1CTRL3 | 0x010  | 0x0000 30D2 |
| XMC_BK1TMG3  | 0x014  | 0x0FFF FFFF |
| XMC_BK1CTRL4 | 0x018  | 0x0000 30D2 |
| XMC_BK1TMG4  | 0x01C  | 0x0FFF FFFF |
| XMC_BK2CTRL  | 0x060  | 0x0000 0018 |
| XMC_BK2IS    | 0x064  | 0x0000 0040 |
| XMC_BK2TMGRG | 0x068  | 0xFCFC FCFC |
| XMC_BK2TMGSP | 0x06C  | 0xFCFC FCFC |
| XMC_BK2ECC   | 0x074  | 0x0000 0000 |
| XMC_BK3CTRL  | 0x080  | 0x0000 0018 |
| XMC_BK3IS    | 0x084  | 0x0000 0040 |
| XMC_BK3TMGRG | 0x088  | 0xFCFC FCFC |
| XMC_BK3TMGSP | 0x08C  | 0xFCFC FCFC |
| XMC_BK3ECC   | 0x094  | 0x0000 0000 |
| XMC_BK4CTRL  | 0xA00  | 0x0000 0018 |
| XMC_BK4IS    | 0xA40  | 0x0000 0040 |

|               |       |             |
|---------------|-------|-------------|
| XMC_BK4TMGCM  | 0x0A8 | 0xFCFC FCFC |
| XMC_BK4TMGAT  | 0x0AC | 0xFCFC FCFC |
| XMC_BK4TMGIO  | 0xB0  | 0xFCFC FCFC |
| XMC_BK1TMGWR1 | 0x104 | 0xFFFF FFFF |
| XMC_BK1TMGWR2 | 0x10C | 0xFFFF FFFF |
| XMC_BK1TMGWR3 | 0x114 | 0xFFFF FFFF |
| XMC_BK1TMGWR4 | 0x11C | 0xFFFF FFFF |
| XMC_EXT1      | 0x220 | 0x0000 0808 |
| XMC_EXT2      | 0x224 | 0x0000 0808 |
| XMC_EXT3      | 0x228 | 0x0000 0808 |
| XMC_EXT4      | 0x22C | 0x0000 0808 |
| SDRAM_CTRL1   | 0x140 | 0x0000 02D0 |
| SDRAM_CTRL2   | 0x144 | 0x0000 02D0 |
| SDRAM_TM1     | 0x148 | 0xFFFF FFFF |
| SDRAM_TM2     | 0x14C | 0xFFFF FFFF |
| SDRAM_CMD     | 0x150 | 0x0000 0007 |
| SDRAM_RCNT    | 0x154 | 0x0000 0000 |
| SDRAM_STS     | 0x158 | 0x0000 0000 |

## 24.8.1 NOR Flash and PSRAM control registers

### 24.8.1.1 SRAM/NOR Flash chip select control register 1 (XMC\_BK1CTRL1)

Accessed by words

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                        |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                         |
| Bit 19     | MWMC     | 0x0         | rw   | Memory write mode control<br>0: Write operations are performed in asynchronous mode<br>1: Write operations are performed in synchronous mode                                                                                                       |
| Bit 18: 16 | CRPGS    | 0x0         | rw   | CRAM page size<br>Cellular RAM 1.5 does not allow synchronous access to cross the address boundaries between pages. When these bits are configured in synchronous mode, the XMC will automatically split the access when the page size is reached. |
| Bit 15     | NWASEN   | 0x0         | rw   | 000: No split access when crossing address boundary (default value)<br>001: 128 bytes<br>010: 256 bytes<br>011: 512 bytes<br>100: 1024 bytes<br>Others: Reserved.                                                                                  |
| Bit 14     | RWTD     | 0x0         | rw   | NWAIT in asynchronous transfer enable<br>0: NWAIT signal is disabled<br>1: NWAIT signal is enable                                                                                                                                                  |
| Bit 13     | NWSEN    | 0x1         | rw   | Read-write timing different<br>Different timings are used for read and write operations, that is, the XMC_BK1TMGWR1 register is enabled.<br>0: Same timings for read and write operations<br>1: Different timings for read and write operations    |

|          |          |     |      |                                                                                                                                                                                                         |
|----------|----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 1: NWAIT signal is enabled                                                                                                                                                                              |
| Bit 12   | WEN      | 0x1 | rw   | Write enable<br>0: Disabled<br>1: Enabled                                                                                                                                                               |
| Bit 11   | NWTCFG   | 0x0 | rw   | NWAIT timing configuration<br>It is valid only in synchronous mode.<br>0: NWAIT signal is active one data cycle before the wait state<br>1: NWAIT signal is active one data cycle during the wait state |
| Bit 10   | WRAPEN   | 0x0 | rw   | Wrapped enable<br>This bit defines whether the XMC will split a wrapped AHB access into two accesses.<br>0: Direct wrapped access is not allowed<br>1: Direct wrapped access is allowed                 |
| Bit 9    | NWPOL    | 0x0 | rw   | NWAIT polarity<br>This bit defines the polarity of the NWAIT signal in synchronous mode.<br>0: NWAIT active low<br>1: NWAIT active high                                                                 |
| Bit 8    | SYNCBEN  | 0x0 | rw   | Synchronous burst enable<br>This bit allows synchronous access to Flash memories.<br>0: Synchronous burst disabled<br>1: Synchronous burst enabled                                                      |
| Bit 7    | Reserved | 0x1 | resd | Kept at its default value.                                                                                                                                                                              |
| Bit 6    | NOREN    | 0x1 | rw   | Nor flash access enable<br>0: Nor flash access is disabled<br>1: Nor flash access is enabled                                                                                                            |
| Bit 5: 4 | EXTMDBW  | 0x1 | rw   | External memory data bus width<br>This field defines the external memory data bus width.<br>00: 8 bits<br>01: 16 bits<br>10: Reserved<br>11: Reserved                                                   |
| Bit 3: 2 | DEV      | 0x2 | rw   | Memory device type<br>00: SRAM/ROM<br>01: PSRAM (Cellular RAM or CRAM)<br>10: NOR Flash<br>11: Reserved                                                                                                 |
| Bit 1    | ADMUXEN  | 0x1 | rw   | Address/data multiplexing enable<br>0: Address/data not multiplexed<br>1: Address/data multiplexed                                                                                                      |
| Bit 0    | EN       | 0x1 | rw   | Memory bank enable<br>0: Memory bank disabled<br>1: Memory bank enabled                                                                                                                                 |

#### 24.8.1.2SRAM/NOR Flash chip select control register x (x=2, 3, 4)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                      |
| Bit 19     | MWMC     | 0x0         | rw   | Memory write mode control<br>0: Write operations are performed in asynchronous mode<br>1: Write operations are performed in synchronous mode                                                                                                                                                                                                                                    |
| Bit 18: 16 | CRPGS    | 0x0         | rw   | CRAM page size<br>Cellular RAM 1.5 does not allow synchronous access to cross the address boundaries between pages. When these bits are configured in synchronous mode, the XMC will automatically split the access when the page size is reached.<br>000: No split access when crossing address boundary (default value)<br>001: 128 bytes<br>010: 256 bytes<br>011: 512 bytes |

|          |          |     |      |                                                                                                                                                                                                                                                 |
|----------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 100: 1024 bytes<br>Others: Reserved.                                                                                                                                                                                                            |
| Bit 15   | NWASEN   | 0x0 | rw   | NWAIT enable during asynchronous transfer<br>0: NWAIT signal is disabled<br>1: NWAIT signal is enable                                                                                                                                           |
| Bit 14   | RWTD     | 0x0 | rw   | Read-write timing different<br>Different timings are used for read and write operations, that is, the XMC_BK1TMGWRx register is enabled.<br>0: Same timings for read and write operations<br>1: Different timings for read and write operations |
| Bit 13   | NWSEN    | 0x1 | rw   | NWAIT enable during synchronous transfer<br>0: NWAIT signal is disabled<br>1: NWAIT signal is enabled                                                                                                                                           |
| Bit 12   | WEN      | 0x1 | rw   | Write enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                       |
| Bit 11   | NWTCFG   | 0x0 | rw   | NWAIT timing configuration<br>It is valid only in synchronous mode.<br>0: NWAIT signal is active one data cycle before the wait state<br>1: NWAIT signal is active one data cycle during the wait state                                         |
| Bit 10   | WRAPEN   | 0x0 | rw   | Wrapped enable<br>This bit defines whether the XMC will split a wrapped AHB access into two accesses.<br>0: Direct wrapped access is not allowed<br>1: Direct wrapped access is allowed                                                         |
| Bit 9    | NWPOL    | 0x0 | rw   | NWAIT polarity<br>This bit defines the polarity of the NWAIT signal in synchronous mode.<br>0: NWAIT active low<br>1: NWAIT active high                                                                                                         |
| Bit 8    | SYNCBEN  | 0x0 | rw   | Synchronous burst enable<br>This bit allows synchronous access to Flash memories.<br>0: Synchronous burst disabled<br>1: Synchronous burst enabled                                                                                              |
| Bit 7    | Reserved | 0x1 | resd | Kept at its default value.                                                                                                                                                                                                                      |
| Bit 6    | NOREN    | 0x1 | rw   | Nor flash access enable<br>0: Nor flash access is disabled<br>1: Nor flash access is enabled                                                                                                                                                    |
| Bit 5: 4 | EXTMDBW  | 0x1 | rw   | External memory data bus width<br>This field defines the external memory data bus width.<br>00: 8 bits<br>01: 16 bits<br>10: Reserved<br>11: Reserved                                                                                           |
| Bit 3: 2 | DEV      | 0x0 | rw   | Memory device type<br>00: SRAM/ROM<br>01: PSRAM (Cellular RAM or CRAM)<br>10: NOR Flash<br>11: Reserved                                                                                                                                         |
| Bit 1    | ADMUXEN  | 0x1 | rw   | Address/data multiplexing enable<br>0: Address/data not multiplexed<br>1: Address/data multiplexed                                                                                                                                              |
| Bit 0    | EN       | 0x0 | rw   | Memory bank enable<br>0: Memory bank disabled<br>1: Memory bank enabled                                                                                                                                                                         |

### 24.8.1.3 SRAM/NOR Flash chip select timing register x (XMC\_BK1TMGx) (x=1,2,3,4)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                        |
|            |          |             |      | Asynchronous mode<br>This field is valid only when the RWTD bit is enabled.<br>00: Mode A<br>01: Mode B<br>10: Mode C<br>11: Mode D                                                                                                                                               |
| Bit 29: 28 | ASYNCM   | 0x0         | rw   | Data latency<br>This field is valid only in synchronous mode.                                                                                                                                                                                                                     |
| Bit 27: 24 | DTLAT    | 0xF         | rw   | 0000: 1 extra XMC_CLK cycle is inserted<br>0001: 2 extra XMC_CLK cycles are inserted<br>.....<br>1111: 16 extra XMC_CLK cycles are inserted                                                                                                                                       |
| Bit 23: 20 | CLKPSC   | 0xF         | rw   | Clock prescaler<br>This field is valid only in synchronous mode. It defines the frequency of the XMC_CLK clock.<br>0000: Reserved<br>0001: XMC_CLK cycle = 2 x HCLK clock cycles<br>0010: XMC_CLK cycle = 3 x HCLK clock cycles<br>.....<br>1111: XMC_CLK cycle = 6 x HCLK cycles |
| Bit 19: 16 | BUSLAT   | 0xF         | rw   | Bus latency<br>To avoid data bus conflict, a latency is inserted on the data bus after one read operation in multiplexed or synchronous mode.<br>0000: 1 HCLK cycle is inserted<br>0001: 2 HCLK cycles are inserted<br>.....<br>1111: 16 HCLK cycles are inserted                 |
| Bit 15: 8  | DTST     | 0xFF        | rw   | Data setup time<br>00000000: 1 extra HCLK cycle is inserted<br>00000001: 2 extra HCLK cycles are inserted<br>.....<br>11111111: 256 extra HCLK cycles are inserted                                                                                                                |
| Bit 7: 4   | ADDRHT   | 0xF         | rw   | Address-hold time<br>0000: 1 HCLK cycle is inserted<br>0001: 2 extra HCLK cycles are inserted<br>.....<br>1111: 16 extra HCLK cycles are inserted                                                                                                                                 |
| Bit 3: 0   | ADDRST   | 0xF         | rw   | Address setup time<br>0000: 1 HCLK cycle is inserted<br>0001: 2 extra HCLK cycles are inserted<br>.....<br>1111: 16 extra HCLK cycles are inserted                                                                                                                                |

### 24.8.1.4 SRAM/NOR Flash write timing register x (XMC\_BK1TMGWRx), x=1,2,3,4

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                          |
|            |          |             |      | Asynchronous mode<br>This field is valid only when the RWTD bit is enabled.<br>00: Mode A<br>01: Mode B<br>10: Mode C<br>11: Mode D |
| Bit 27: 20 | Reserved | 0xFF        | resd | Kept at its default value.                                                                                                          |

|            |        |     |    |                                                                                                                                                                                                                                                                   |
|------------|--------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        |     |    | Bus latency<br>To avoid data bus conflict, a latency is inserted on the data bus after one read operation in multiplexed or synchronous mode.<br>0000: 1 HCLK cycle is inserted<br>0001: 2 HCLK cycles are inserted<br>.....<br>1111: 16 HCLK cycles are inserted |
| Bit 19: 16 | BUSLAT | 0xF | rw | Data setup time<br>00000000: 1 extra HCLK cycle is inserted<br>00000001: 2 extra HCLK cycles are inserted<br>.....<br>11111111: 256 extra HCLK cycles are inserted                                                                                                |
| Bit 7: 4   | ADDRHT | 0xF | rw | Address-hold time<br>0000: 1 extra HCLK cycle is inserted<br>0001: 2 extra HCLK cycles are inserted<br>.....<br>1111: 16 extra HCLK cycles are inserted                                                                                                           |
| Bit 3: 0   | ADDRST | 0xF | rw | Address setup time<br>0000: 1 extra HCLK cycle is inserted<br>0001: 2 extra HCLK cycles are inserted<br>.....<br>1111: 16 extra HCLK cycles are inserted                                                                                                          |

## 24.8.1.5 SRAM/NOR Flash extra timing register x (XMC\_EXTx) (x=1,2,3,4)

Accessed by words.

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved  | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 15: 8  | BUSLATR2R | 0x08        | rw   | Bus turnaround phase for consecutive read duration<br>This field is used to define the bus turnaround phase duration for consecutive read operations. A delay is inserted between two consecutive read operations in order to avoid bus conflicts.<br>00000000: 1 HCLK cycle is inserted for consecutive read operations<br>00000001: 2 HCLK cycles are inserted for consecutive read operations<br>.....<br>00001000: 9 HCLK cycles are inserted for consecutive read operations (default value)<br>.....<br>11111111: 256 HCLK cycles are inserted for consecutive read operations        |
| Bit 7: 0   | BUSLATW2W | 0x08        | rw   | Bus turnaround phase for consecutive write duration<br>This field is used to define the bus turnaround phase duration for consecutive write operations. A delay is inserted between two consecutive write operations in order to avoid bus conflicts.<br>00000000: 1 HCLK cycle is inserted for consecutive write operations<br>00000001: 2 HCLK cycles are inserted for consecutive write operations<br>.....<br>00001000: 9 HCLK cycles are inserted for consecutive write operations (default value)<br>.....<br>11111111: 256 HCLK cycles are inserted for consecutive write operations |

## 24.8.2 NAND Flash control registers

### 24.8.2.1 NAND Flash control register x (XMC\_BKxCTRL) (x=2,3)

Accessed by words.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 20 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                   |
| Bit 19: 17 | ECCPGS   | 0x0         | rw   | ECC page size<br>000: 256 bytes<br>001: 512 bytes<br>010: 1024 bytes<br>011: 2048 bytes<br>100: 4096 bytes<br>101: 8192 bytes                                |
| Bit 16: 13 | TAR      | 0x0         | rw   | ALE to RE delay<br>This field specifies the delay from the falling edge of the ALE to that of the RE.<br>0000: 1 HCLK cycle<br>.....<br>1111: 16 HCLK cycles |
| Bit 12: 9  | TCR      | 0x0         | rw   | CLE to RE delay<br>This field specifies the delay from the falling edge of the CLE to that of the RE.<br>0000: 1 HCLK cycle<br>.....<br>1111: 16 HCLK cycles |
| Bit 8: 7   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                   |
| Bit 6      | ECCEN    | 0x0         | rw   | ECC enable<br>0: ECC disabled<br>1: ECC enabled                                                                                                              |
| Bit 5: 4   | EXTMDBW  | 0x1         | rw   | External memory data bus width<br>This field specifies the external NAND Flash width.<br>00: 8 bits<br>01: 16 bits<br>10: Reserved<br>11: Reserved           |
| Bit 3      | DEV      | 0x1         | rw   | Memory device type<br>0: Reserved<br>1: NAND Flash                                                                                                           |
| Bit 2      | EN       | 0x0         | rw   | Memory bank enable<br>0: Memory bank disabled<br>1: Memory bank enabled                                                                                      |
| Bit 1      | NWEN     | 0x0         | rw   | Wait feature enable<br>This bit is used to enable NAND Flash wait function.<br>0: Disabled<br>1: Enabled                                                     |
| Bit 0      | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                   |

### 24.8.2.2 Interrupt enable and FIFO status register x (XMC\_BKxIS) (x=2,3)

Accessed by words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                        |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                         |
| Bit 6     | FIFOE    | 0x1         | rw   | FIFO empty<br>This bit is set by hardware when the FIFO is empty.<br>0: FIFO is not empty<br>1: FIFO is empty<br>XMC FIFO size is 16 words. It is used to store the data from AHB. |
| Bit 5     | FEIEN    | 0x0         | rw   | Falling edge interrupt enable<br>0: Falling edge interrupt disabled<br>1: Falling edge interrupt enabled                                                                           |
| Bit 4     | HЛИEN    | 0x0         | rw   | High-level interrupt enable                                                                                                                                                        |

|       |       |     |    |                                                                                                                                                              |
|-------|-------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | 0: High-level interrupt disabled<br>1: High-level interrupt enabled                                                                                          |
| Bit 3 | REIEN | 0x0 | rw | Rising edge interrupt enable<br>0: Rising edge interrupt disabled<br>1: Rising edge interrupt enabled                                                        |
| Bit 2 | FES   | 0x0 | rw | Falling edge status<br>This bit is set by hardware and cleared by software.<br>0: No falling edge interrupt generated<br>1: Falling edge interrupt generated |
| Bit 1 | HLS   | 0x0 | rw | High-level status<br>This bit is set by hardware and cleared by software.<br>0: No high level interrupt generated<br>1: High level interrupt generated       |
| Bit 0 | RES   | 0x0 | rw | Rising edge status<br>This bit is set by hardware and cleared by software.<br>0: No rising edge interrupt generated<br>1: Rising edge interrupt generated    |

#### 24.8.2.3 Regular memory timing register x (XMC\_BKxTMGRG) (x=2,3)

Accessed by words.

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                |
|------------|---------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | RGDHIZT | 0xFC        | rw   | Regular memory databus High resistance time<br>This field defines the databus high resistance duration when write access to NAND Flash is started in a regular space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |
| Bit 23: 16 | RGHT    | 0xFC        | rw   | Regular memory hold time<br>This field defines the databus hold time when access to NAND Flash in a regular memory.<br>00000000: Reserved<br>00000001: 1 HCLK cycle is inserted<br>.....<br>11111111: 255 HCLK cycles are inserted                                                                                         |
| Bit 15: 8  | RGWT    | 0xFC        | rw   | Regular memory wait time<br>Specifies the regular memory wait time when the XMC_NWE and XMC_NOE is low.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted                                                               |
| Bit 7: 0   | RGST    | 0xFC        | rw   | Regular memory setup time<br>This field defines the address setup time when access to NAND Flash in a regular memory.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted                                                 |

#### 24.8.2.4 Special memory timing register x (XMC\_BKxTMGSP) (x=2,3)

Accessed by words.

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                |
|------------|---------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | SPDHIZT | 0xFC        | rw   | Special memory databus High resistance time<br>This field defines the databus high resistance duration when write access to NAND Flash is started in a special space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |
| Bit 23: 16 | SPHT    | 0xFC        | rw   | Special memory hold time                                                                                                                                                                                                                                                                                                   |

|           |      |      |    |                                                                                                                                                                                                                                                                            |
|-----------|------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |      |      |    | This field defines the databus hold time when access to NAND Flash in a special memory.<br>00000000: Reserved<br>00000001: 1 HCLK cycle is inserted<br>.....<br>11111111: 255 HCLK cycles are inserted                                                                     |
| Bit 15: 8 | SPWT | 0xFC | rw | Special memory wait time<br>Specifies the special memory wait time when the XMC_NWE and XMC_NOE is low.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted               |
| Bit 7: 0  | SPST | 0xFC | rw | Special memory setup time<br>This field defines the address setup time when access to NAND Flash in a special memory.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |

## 24.8.2.5 ECC value register x (XMC\_BKxCC) (x=2,3)

Accessed by words.

| Bit       | Name | Reset value | Type | Description                                               |
|-----------|------|-------------|------|-----------------------------------------------------------|
| Bit 31: 0 | ECC  | 0x0000 0000 | ro   | EECC value<br>This field contains the computed ECC value. |

## 24.8.3 PC card controller registers

### 24.8.3.1 PC card control register (XMC\_BK4CTRL)

Accessed by words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                 |
| Bit 2     | EN       | 0x0         | rw   | Memory bank enable<br>0: Memory bank disabled<br>1: Memory bank enabled                                                                    |
| Bit 1     | NWEN     | 0x0         | rw   | Wait feature enable<br>This bit is used to enable PC card memory bank wait feature.<br>0: Wait feature disabled<br>1: Wait feature enabled |
| Bit 0     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                 |

### 24.8.3.2 Interrupt enable and FIFO status register 4 (XMC\_BK4IS)

Accessed by words.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                        |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 7 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                         |
| Bit 6     | FIFOE    | 0x1         | rw   | FIFO empty<br>This bit is set by hardware when the FIFO is empty.<br>0: FIFO is not empty<br>1: FIFO is empty<br>XMC FIFO size is 16 words. It is used to store the data from AHB. |
| Bit 5     | FEIEN    | 0x0         | rw   | Falling edge interrupt enable<br>0: Falling edge interrupt disabled<br>1: Falling edge interrupt enabled                                                                           |
| Bit 4     | HLIEN    | 0x0         | rw   | High-level interrupt enable<br>0: High-level interrupt disabled<br>1: High-level interrupt enabled                                                                                 |
| Bit 3     | REIEN    | 0x0         | rw   | Rising edge interrupt enable<br>0: Rising edge interrupt disabled<br>1: Rising edge interrupt enabled                                                                              |

|       |     |     |    |                                                                                                                                                              |
|-------|-----|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 2 | FES | 0x0 | rw | Falling edge status<br>This bit is set by hardware and cleared by software.<br>0: No falling edge interrupt generated<br>1: Falling edge interrupt generated |
| Bit 1 | HLS | 0x0 | rw | High-level status<br>This bit is set by hardware and cleared by software.<br>0: No high level interrupt generated<br>1: High level interrupt generated       |
| Bit 0 | RES | 0x0 | rw | Rising edge status<br>This bit is set by hardware and cleared by software.<br>0: No rising edge interrupt generated<br>1: Rising edge interrupt generated    |

#### 24.8.3.3 Common memory timing register 4 (XMC\_BK4TMGCM)

Accessed by words.

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                              |
|------------|---------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | CMDHIZT | 0xFC        | rw   | Common memory databus High resistance time<br>This field defines the databus high resistance duration when write access to NAND Flash is started in a common space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |
| Bit 23: 16 | CMHT    | 0xFC        | rw   | Common memory hold time<br>This field defines the databus hold time when access to NAND Flash in a common space<br>00000000: Reserved<br>00000001: 1 HCLK cycle is inserted<br>.....<br>11111111: 255 HCLK cycles are inserted                                                                                           |
| Bit 15: 8  | CMWT    | 0xFC        | rw   | Common memory wait time<br>Specifies the common memory wait time when the XMC_NWE and XMC_NOE is low.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted                                                               |
| Bit 7: 0   | CMST    | 0xFC        | rw   | Common memory setup time<br>This field defines the address setup time when access to NAND Flash in a regular memory.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted                                                |

#### 24.8.3.4 Attribute memory timing register 4 (XMC\_BK4TMGAT)

Accessed by words.

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                     |
|------------|---------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | ATDHIZT | 0xFC        | rw   | Attribute memory databus High resistance time<br>This field defines the databus high resistance duration when write access to NAND Flash is started in an attribute space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |
| Bit 23: 16 | ATHT    | 0xFC        | rw   | Attribute memory hold time<br>This field defines the databus hold time when access to NAND Flash in an attribute space.<br>00000000: Reserved<br>00000001: 1 HCLK cycle is inserted<br>.....<br>11111111: 255 HCLK cycles are inserted                                                                                          |

|           |      |      |    |                                                                                                                                                                                                                                                                                |
|-----------|------|------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |      |      |    | Attribute memory wait time<br>Specifies the attribute memory wait time when the XMC_NWE and XMC_NOE is low.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted               |
| Bit 15: 8 | ATWT | 0xFC | rw | Attribute memory setup time<br>This field defines the address setup time when access to NAND Flash in an attribute space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |

### 24.8.3.5IO space timing register 4 (XMC\_BK4TMGIO)

Accessed by words.

| Bit        | Name    | Reset value | Type | Description                                                                                                                                                                                                                                                                                                       |
|------------|---------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | IODHIZT | 0xFC        | rw   | I/O space databus High resistance time<br>This field defines the databus high resistance duration when write access to NAND Flash is started in an IO space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted |
| Bit 23: 16 | IOHT    | 0xFC        | rw   | I/O space hold time<br>This field defines the databus hold time when access to NAND Flash in an IO space.<br>00000000: Reserved<br>00000001: 1 HCLK cycle is inserted<br>.....<br>11111111: 255 HCLK cycles are inserted                                                                                          |
| Bit 15: 8  | ATWT    | 0xFC        | rw   | Attribute memory wait time<br>Specifies the IO wait time when the XMC_NWE and XMC_NOE is low.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted                                                                |
| Bit 7: 0   | IOST    | 0xFC        | rw   | IO space setup time<br>This field defines the address setup time when access to NAND Flash in an IO space.<br>00000000: 0 HCLK cycle is inserted<br>00000001: 1 additional HCLK cycle is inserted<br>.....<br>11111111: 255 additional HCLK cycles are inserted                                                   |

### 24.8.4 SDRAM controller registers

#### 24.8.4.1 SDRAM control register 1, 2 (SDRAM\_CTRL1, SDRAM\_CTRL2)

This register contains the control parameters for each SDRAM memory bank.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 15 | Reserved | 0x00000     | resd | Kept at its default value.                                                                                                                                                                                                                                                                                     |
| Bit 14: 13 | RD       | 0x0         | rw   | Read delay<br>This field defines the delay (in HCLK clock cycles) for reading data after CAS latency.<br>00: No HCLK clock cycle delay<br>01: 1 HCLK clock cycle delay<br>10: 2 HCLK clock cycle delay<br>11: Reserved, do not use.<br>Note: The corresponding bits in the CTRL2 register are "don't care bit" |
| Bit 12     | BSTR     | 0x0         | rw   | Burst read                                                                                                                                                                                                                                                                                                     |

|            |        |     |    |                                                                                                                                                                                                                                                                                                                                                              |
|------------|--------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |        |     |    | When this bit is set, it indicates that single AHB requests (single or burst) are processed as bursts. Several data will be prefetched and stored into the FIFO.<br>0: Single read requests are not processed as bursts<br>1: Single read requests are always processed as bursts<br>Note: The corresponding bits in the CTRL2 register are "don't care bit" |
| Bit 11: 10 | CLKDIV | 0x0 | rw | Clock division configuration<br>SDRAM clock configuration.<br>00: SDCLK clock disabled<br>01: HCLK/4<br>10: HCLK/2<br>11: HCLK/3<br>Note: The corresponding bits in the CTRL2 register are "don't care bit"                                                                                                                                                  |
| Bit 9      | WRP    | 0x0 | rw | Write protection<br>This bit is set to enable the SDRAM write protection.<br>0: Write access allowed<br>1: Write access forbidden                                                                                                                                                                                                                            |
| Bit 8: 7   | CAS    | 0x0 | rw | CAS latency<br>This field is used to select CAS latency.<br>00: Reserved, do not use.<br>01: 1 cycle<br>10: 2 cycles<br>11: 3 cycles                                                                                                                                                                                                                         |
| Bit 6      | INBK   | 0x0 | rw | Internal banks<br>This bit is used to define the number of internal banks.<br>0: 2 internal BANKs<br>1: 4 internal BANKs                                                                                                                                                                                                                                     |
| Bit 5: 4   | DB     | 0x0 | rw | SDRAM data bus<br>This field enables 8-bit or 16-bit data bus width.<br>00: 8 bits<br>01: 16 bits<br>10: Reserved, do not use.<br>11: Reserved, do not use.                                                                                                                                                                                                  |
| Bit 3: 2   | RA     | 0x0 | rw | Row address<br>This field defines the number of a row address, including 11 bits, 12 bits and 13 bits.<br>00: 11 bits<br>01: 12 bits<br>10: 13 bits<br>11: Reserved, do not use.                                                                                                                                                                             |
| Bit 1: 0   | CA     | 0x0 | rw | Column address<br>This field defines the number of a column address, including 8 bits, 9 bits, 10 bits and 13 bits.<br>00: 8 bits<br>01: 9 bits<br>10: 10 bits<br>11: 11 bits                                                                                                                                                                                |

#### 24.8.4.2 SDRAM timing register 1, 2 (SDRAM\_TM1, SDRAM\_TM2)

This register contains the timing parameters of each SDRAM bank.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                   |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 28 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                    |
| Bit 27: 24 | TRCD     | 0xF         | rw   | Row active to Read/Write delay<br>This field defines the delay between the activate command and a read/write command in number of clock cycles.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles |
| Bit 23:20  | TRP      | 0xF         | rw   | Precharge to active delay<br>This field defines the delay between a precharge command and another command in number of clock                                                                                  |

|            |      |     |    |                                                                                                                                                                                                                                             |
|------------|------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |      |     |    | cycles.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles                                                                                                                                                                       |
| Bit 19: 16 | TWR  | 0xF | rw | Write Recovery delay<br>This field defines the delay between a write command and a precharge command in number of clock cycles.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles                                               |
| Bit 15: 12 | TRC  | 0xF | rw | Refresh to active delay<br>This field defines the delay between the refresh command and the activate command, as well as the delay between two consecutive refresh commands.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles  |
| Bit 11: 8  | TRAS | 0xF | rw | Self refresh time<br>This field defines the minimum self-refresh period in number of clock cycles.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles                                                                            |
| Bit 7: 4   | TXSR | 0xF | rw | Exit Self-refresh to active delay<br>This field defines the delay from exiting the self-refresh command to issuing an activate command in number of clock cycles.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles             |
| Bit 3: 0   | TMRD | 0xF | rw | Load mode register program to active delay<br>This field defines the delay between a load mode register command and an activate or refresh command in number of clock cycles.<br>0000: 1 cycle<br>0001: 2 cycles<br>....<br>1111: 16 cycles |

*Note: If two SDRAM devices are used, the TRP and TRC timings must be programmed with the timings of the slowest devices.*

#### 24.8.4.3 SDRAM command register (SDRAM\_CMD)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                      |
| Bit 22: 9  | MRD      | 0x0000      | rw   | Mode Register data<br>Refer to the SDRAM specifications for details.                                                                                                                                                                                                            |
| Bit 8: 5   | ART      | 0x0         | rw   | Auto-refresh times<br>This field defines the number of consecutive auto-refresh commands issued when MODE = "011".<br>0000: 1 auto-refresh cycle<br>0001: 2 auto-refresh cycles<br>....<br>1110: 15 auto-refresh cycles<br>1111: Reserved                                       |
| Bit 4      | BK1      | 0x0         | wo   | SDRAM Bank 1<br>This bit indicates whether the command will be sent to the SDRAM Bank 1.<br>0: Command not sent to SDRAM Bank 1<br>1: Command sent to SDRAM Bank 1                                                                                                              |
| Bit 3      | BK2      | 0x0         | wo   | SDRAM Bank 2<br>This bit indicates whether the command will be sent to the SDRAM Bank 2.<br>0: Command not sent to SDRAM Bank 2<br>1: Command sent to SDRAM Bank 2                                                                                                              |
| Bit 2: 0   | CMD      | 0x0         | wo   | SDRAM Command<br>This field defines the command issued to the SDRAM device.<br>000: Normal mode<br>001: Clock configuration enable<br>010: Precharge all banks<br>011: Auto refresh<br>100: Load mode register<br>101: Self refresh<br>110: Power-down command<br>111: Reserved |

#### 24.8.4.4 SDRAM refresh timer register (SDRAM\_RCNT)

This register is used to set the refresh rate of the SDRAM, in number of SDRAM CLK clock cycles. The RC has to be configured as a non-zero value in order to perform a correct refresh operation. The RC value cannot be changed after initialization.

Refresh operation has priority over a read/write operation. However, if a read/write operation is in progress while a new refresh request occurs, the refresh operation starts only after the read/write operation is complete. It is recommended that the RC value is smaller than the calculated value in order to ensure the anticipated refresh rate.

This register is shared by the SDRAM Bank 1 and Bank 2.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 15 | Reserved | 0x00000     | resd | Kept at its default value.                                                                                                                                                                                                                                                      |
| Bit 14     | ERIEN    | 0x0         | rw   | Error interrupt enable<br>0: Error interrupt disabled<br>1: Error interrupt enabled                                                                                                                                                                                             |
| Bit 13: 1  | RC       | 0x0000      | rw   | Refresh counter<br>This 13-bit field defines the refresh rate of the SDRAM device. It is expressed in number of clock cycles. It must be set at least to 41 clock cycles.<br>Refresh rate = (RC + 1) x SDRAM clock frequency<br>RC = (SDRAM refresh period/number of rows) - 20 |
| Bit 0      | ERRC     | 0x0         | wo   | Error flag clear<br>This bit is used to clear the error flag (ER) in the status register.<br>0: No effect<br>1: Refresh error flag is cleared.                                                                                                                                  |

Note: The programmed COUNT value must not be equal to the sum of the following timings:  
 $TWR+TRP+TRC+TRCD+4$  memory clock cycles.

#### 24.8.4.5 SDRAM status register (SDRAM\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                 |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 6 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                  |
| Bit 5     | BUSY     | 0x0         | ro   | Busy<br>This bit indicates the status of the current SDRAM controller.<br>0: Idle<br>1: Busy                                                |
| Bit 4: 3  | BK2STS   | 0x0         | ro   | Bank2 status<br>This field defines the status mode of the SDRAM Bank 2.<br>00: Normal mode<br>01: Auto-refresh mode<br>10: Power-down mode  |
| Bit 2: 1  | BK1STS   | 0x0         | ro   | Bank 1 Status<br>This field defines the status mode of the SDRAM Bank 1.<br>00: Normal mode<br>01: Auto-refresh mode<br>10: Power-down mode |
| Bit 0     | ERR      | 0x0         | ro   | Error flag<br>0: No refresh error has been detected<br>1: A refresh error has been detected                                                 |

## 25 SDIO interface

### 25.1 SDIO introduction

The SD/SDIO MMC card host interface (SDIO) provides an interface between the AHB peripheral bus and MultiMediaCards (MMC), SD memory cards and SDIO cards.

SD memory card and SDI/O card system specifications are available through the SD card association website [www.sdcard.org](http://www.sdcard.org).

The MultiMediaCard system specifications published by the MMCA technical committee are available through the MultiMediaCard association website [www.mmca.org](http://www.mmca.org).

### 25.2 SDIO main features

- Full compatibility with SD memory card specifications version 2.0
- Full compatibility with SDI/O card specification version 2.0 and support 1-bit and 4-bit databus modes.
- Full compatibility with MultiMedia card specification version 4.2 and support 1-bit, 4-bit and 8-bit databus modes.
- Full compatibility with previous versions of MultiMedia card specifications
- DMA transfer
- Data transfer up to 50 MHz in 8-bit bus mode
- Interrupt requests

*Note: The SDIO is not compatible with SPI communication mode. It supports only one SD/SDIO/MMC 4.2 card at any one time.*

Communication on the bus is based on command and data transfers.

- Command: A command is a token that starts an operation. Commands are sent from the host either to a single card (addressed command) or to all connected cards (broadcast command). Commands are transferred serially on the CMD line.
- Response: A response is a token that is sent from a card to the host as an answer to a previously received command. Responses are transferred serially on the CMD line.
- Data: Data can be transferred from the card to the host or vice versa. Data is transferred via the SDIO\_D data line.

The basic operation on the MMC card/SD/SDI I/O bus is the command/response structure. These types of bus operation transfer their information through the command or bus mechanism. In addition, some operations have a data token.

Data transfers to/from SD/SDIO memory cards are done in data blocks. Data blocks are always followed by CRC bit, defining single and multiple block operations. Data transfers to/from MMC are done in data blocks or streams, as shown in Figure below.

Figure 25-1 SDIO “no response” and “response” operations



Figure 25-2 SDIO multiple block read operation



Figure 25-3 SDIO multiple block write operation



Note: The SDIO will not send any data as long as the Busy signal is set (SDIO\_D0 pulled low).

Figure 25-4 SDIO sequential read operation



Figure 25-5 SDIO sequential write operation



## 25.3 Functional description

### 25.3.1 Card functional description

All the communications between the host and the cards are controlled by the card. The host sends two different types of commands: broadcast command and addressed (point-to-point) command.

- Broadcast command: applicable to all cards, some need responses
- Addressed command: sent to the addressed card, and responses received from the card

Memory card defines two types of operational modes:

- Card identification mode
- Data transfer mode

#### 25.3.1.1 Card identification mode

In card identification mode, the host resets all cards, validates the operation voltage range, identifies cards and sets a relative card address (RCA) for each card on the CMD. All communications in the card identification mode use the command line (CMD).

##### Card identification process

The card identification process varies from card to card, and the host sends different commands. There are SD, SDI/O and MMC cards. It is possible to send a CMD5 command to identify the type of a card. If the host receives a response, it is a SDI/O card. If no response is received, the host will continue to send ACMD41 command, if a response is received, it is a SD card; otherwise a MMC card.

The card identification process is described as follows:

1. The bus is activated to confirm whether the card is connected or not. The clock frequency is at 0-400kHz during the card identification process.
2. The SDIO host sends a SD card, SDI/O card or MMC card.
3. Card Initialization
  - SD card: The SDIO host sends CMD2 (ALL\_SEND\_CID) to obtain its unique CID number. After receiving a response (CID number) from the card, the host will send CMD3 (SEND\_RELATIVE\_ADDR), instructing the card to issue the relative card address (RCA), which is shorter than the CID and is used to address the card in the data transfer mode.
  - SDI/O card: The SDIO host sends CMD3 (SEND\_RELATIVE\_ADDR) to instruct the card to release the relative card address (RCA), which is shorter than the CID and is used to address the card in the data transfer mode.
  - MMC card: The SDIO host sends CMD1 (SEND\_OP\_COND), followed by CMD2 and CMD3.
4. If the host wants to assign another RCA number, it can instruct the card to issue a new number by sending another CMD3 command. The last RCA is the actual RCA number of the card. The host repeats the card identification process (CMD2 and CMD3 cycle of each card)

### 25.3.1.2 Data transfer mode

The host will enter data transfer mode after identifying all cards on the bus. In data transfer mode, the host can operate cards within the range of 0 - 50MHz. It can send CMD9 (SEND\_CSD) to get data specific to a card (CSD register) such as block length and card memory size. All communications between the host and the selected card are point-to-point transferred, and the CMD bus will confirm all addressed commands as a response. Data transfer read/write can be done in data block mode or stream mode, configured by the TFRMODE bit in the SDIO\_DTCTRL register. In the data stream mode, data is transferred in bytes and without CRC appended to the end of each data block.

#### Wide bus selection/deselection

Wide bus (4-bit bus width) operation mode is selected or deselected by using ACMD6 (SET\_BUS\_WIDTH). The default bus width after power-up or CMD0 (GO\_IDLE\_STATE) is 1 bit. The ACMD6 is only valid in a transfer state, indicating that the bus width can be changed only after a card is selected by CMD7.

#### Stream read/write (MultiMedia card only)

Read:

1. The host sends CMD11 (READ\_DAT\_UNTIL\_STOP) for stream read.
2. Until the host sends CMD12 (STOP\_TRANSMISSION). The stop command has an execution delay due to the serial command transmission and the data transfers stops after the end bit of the stop command.

Write:

1. The host sends CMD20 (WRITE\_DAT\_UNTIL\_STOP) for stream write.
2. Until the host sends CMD12 (STOP\_TRANSMISSION). As the amount of data to be transferred is not determined in advance, the CRC cannot be used. When the memory range is reached, the command will be discarded by the card and remain in a transfer state, and a response is issued by setting the ADDRESS\_OUT\_OF\_RANGE bit.

#### Data block read

In block read mode, the basic unit of data transfer is a block whose maximum size (fixed length 512 bytes) is defined in the CSD (READ\_BL\_LEN). If the READ\_BL\_PARTIAL is set, smaller blocks whose start and end addresses are entirely contained within 512 bytes may also be transmitted. A CRC is appended to the end of each block to ensuring data transfer integrity. Several commands related to data block read are as follows:

- CMD17 (READ\_SINGLE\_BLOCK): initiates a data block read and returns to the transfer state after the completion of the transfer.
- CMD18 (READ\_MULTIPLE\_BLOCK): starts a transfer of several consecutive data blocks.

Data blocks will keep transferring until the host sends CMD12(STOP\_TRANSMISSION). The stop

command has an execution delay due to the serial command transmission and the data transfers stops after the end bit of the stop command.

#### Data block write

During block write (CMD24-27), one or more blocks of data are transferred from the host to the card with a CRC appended to the end of each block. If the CRC failed, the card indicates a failure on the SDIO\_D signal line and the transferred data are discarded and not written, and all transmitted data blocks are ignored.

If the host uses partial blocks with accumulated length is not block aligned, and block misalignment is not allowed (CSD parameter WRITE\_BLK\_MISALIGN is not set), the card will detect the block misalignment error before the beginning of the first misaligned block. The card sets the ADDRESS\_ERROR bit in the SDIO\_STS register and waits the stop command in a receive state while ignoring all further data transfer. If the host attempts to perform write operation on a write-protected area, the write operation will be aborted. In this case, however, the card should set the WP\_VIOLATION bit.

Programming of the CID and CSD registers does not require a block length setting in advance. The transferred data is also CRC protected. If a part of the CSD or CID register is stored in the ROM, then the unchangeable part must match the corresponding part of the receive buffer. If this match failed, then the card will report an error and does not change any register contents. Some cards may require long and unpredictable times to write a block of data. After receiving a block of data and completing the CRC check, the card begins writing and holds the SDIO\_D signal line low if its write buffer is full and unable to accept new data from a new WRITE\_BLOCK command. The host can check the status of the card with SEND\_STATUS command (CMD13) at any time, and the card will respond with its status.

The READY\_FOR\_DATA status bit indicates whether the card can accept new data or whether the write process is still in progress. The host can deselect the card by issuing CMD7 (select another card), which will place the card in the disconnect state and release the SDIO\_D line without interrupting the write operation. When reselecting the card, it will reactivate busy indication by pulling SDIO\_D line to low if the programming is still in progress and the write buffer is unavailable.

### 25.3.1.3 Erase

The erasable unit of the MultiMedia card and SD card is the erase group. The erase group is calculated in write blocks, which are the basic writable units of the card. The size of the erase group is a parameter specific to the card and defined in the CSD.

The host can erase a contiguous range of erase groups. There are three steps to start the erase process, but the commands sent by the MultiMedia card and SD card are different.

1. The host defines the start address of the range using the following command:
  - SD card: issue CMD32 (ERASE\_WR\_BLK\_START)
  - MMC card: issue CMD35 (ERASE\_GROUP\_START)
2. The host defines the end address of the range using the following command:
  - SD card: issue CMD33 (ERASE\_WR\_BLK\_END)
  - MMC card: issue CMD36 (ERASE\_GROUP\_END)
3. The host starts the erase process by sending CMD38 (ERASE)

### 25.3.1.4 Protection management

Three write protection methods are supported in the SDIO card host module to ensure that the protected data is not erased or changed.

#### Mechanical write protect switch

There is a mechanical sliding switch on the side of the card to allow the user to set/clear the write protection on the card. When the sliding switch is positioned with the window open, the card is write-protected, and when the window is closed, the card is not write-protected.

#### Internal card write protection

Card data can be protected against write and erase. The entire card can be permanently write-protected by the manufacturer or the content provider by setting the permanent or temporary write-protect bits in the CSD. For cards that support write protection of groups of sectors by setting the WP\_GRP\_ENABLE bit in the CSD, part of the data can be protected, and the write protection can be changed by the

application. The SET\_WRITE\_PROT commands set the write protection of the addressed group. The CLR\_WRITE\_PROT commands clear the write protection of the addressed group. The SEND\_WRITE\_PROT command is similar to a single block read command. The card sends a data block containing 32 write protection bits (representing 32 write protect groups starting at the specified address) followed by 16 CRC bits. The address field in the write protect commands is a group address in byte units.

### Password protect

The password protection function enables the SDIO card host to lock and unlock a card with a password. The password is stored in the 128-bit PWD register and its size is set in the 8-bit PWD\_LEN register. These registers are nonvolatile so that the content is not erased after power-off.

Locked cards can support certain commands, indicating that the host is allowed to reset, initialize and query for status, but not allowed to access data on the card. When the password is set (PWD\_LEN is nonzero value), the card is locked automatically after power-up.

Like the CSD and CID register write commands, the lock/unlock commands are valid only in a transfer state. The command does not include an address parameter and thus the card must be selected before using it.

The card lock/unlock commands have the structure and bus transaction types of a regular single-block write command. The transferred data block include all the information required for the command (the password setting mode, PWD content and card lock/unlock indication). The command data block size is defined by the SDIO card host module before it sends the card lock/unlock command. The lock/unlock command structure is shown below:

Table 25-1 Lock/unlock command structure

| Byte       | Bit7               | Bit6 | Bit5 | Bit4 | Bit3  | Bit2        | Bit1    | Bit0    |
|------------|--------------------|------|------|------|-------|-------------|---------|---------|
| 0          | Reserved(set to 0) |      |      |      | ERASE | LOCK_UNLOCK | CLR_PWD | SET_PWD |
| 1          | PWDS_LEN           |      |      |      |       |             |         |         |
| 2          |                    |      |      |      |       |             |         |         |
| ...        | password data      |      |      |      |       |             |         |         |
| PWDS_LEN+1 |                    |      |      |      |       |             |         |         |

- ERASE: Setting it will force an erase operation. All other bits must be zero, and only the command byte is sent.
- LOCK\_UNLOCK: Setting it will lock the card. Clearing it will unlock the card. LOCK\_UNLOCK can be set simultaneously with SET\_PWD, but not with the CLR\_PWD.
- CLR\_PWD: Setting it will clear the password data.
- SET\_PWD: Setting this bit will save the password data to memory.
- PWD\_LEN: This bit defines the length of the password in bytes. When the password is changed, the length is the combination of the old and new passwords.
- PWD: password (new or currently used, depending on the command)

The data block size should be defined by the host before it sends the card lock/unlock command. The block length should be equal to or greater than the data structure required for the lock/unlock command.

The following sections list the command sequence to set/clear a password, lock/unlock a card, and force an erase operation.

### Setting the password

1. Select a card using CMD7 (SELECT/DESELECT\_CARD), if none is selected previously
2. Define the block length with CMD16(SET\_BLOCKLEN) to send in the 8-bit card lock/unlock mode, 8-bit PWD\_LEN, and the number of bytes of the new password. When a password is replaced, the block size must take into account the length of both the old and the new passwords sent with the command.
3. Send CMD42(LOCK/UNLOCK) with the appropriate data block size on the data line including the 16-bit CRC. The data block indicates the operation mode (SET\_PWD=1), the length (PWD\_LEN) and the password (PWD). When a password replacement is done, the length value includes the length of the both passwords, the old and the new one, and the PWD field includes the old password (currently used) followed by the new password.
4. When the old password is matched, the new password and its size are saved into the PWD

and PWD\_LEN fields, respectively. When the old password sent is not correct (in size and/or content), the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register, and the old password is not changed. When the old password sent is correct (in size and content), the given new password and its size will be saved in the PWD and the PWD\_LEN registers, respectively.

The password length field (PWD\_LEN) indicates whether a password is currently set or not. When the field is a zero value, it means that a password is not set currently. When the field is nonzero, it means that a password is set and the card locks itself after power-up. It is possible to lock the card immediately in the current power session by setting the LOCK\_UNLOCK bit or sending an additional card lock command.

#### Clearing the password

1. Select a card using CMD7 (SELECT/DESELECT\_CARD), if none is selected previously.
2. Define the block length with CMD16(SET\_BLOCKLEN) to send in the 8-bit card lock/unlock mode, 8-bit PWD\_LEN, and the number of bytes of the new password.
3. Send CMD42(LOCK/UNLOCK) with the appropriate data block size on the data line including the 16-bit CRC. The data block indicates the operation mode (SET\_PWD=1), the length (PWD\_LEN) and the password (PWD). When a password is matched, the PWD field is cleared and PWD\_LEN is set to 0. If the password sent does not correspond to the expected password (in size and/or content), the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register, and the password is not changed.

#### Locking a card

1. Select a card using CMD7 (SELECT/DESELECT\_CARD), if none is selected previously.
2. Define the block length with CMD16(SET\_BLOCKLEN) to send in the 8-bit card lock/unlock mode, 8-bit PWD\_LEN, and the number of bytes of the new password.
3. Send CMD42(LOCK/UNLOCK) with the appropriate data block size on the data line including the 16-bit CRC. The data block indicates the operation mode (SET\_PWD=1), the length (PWD\_LEN) and the password (PWD).
4. When a password is matched, the card is locked and CARD\_IS\_LOCKED is set in the SDIO\_STS register. If the password sent does not correspond to the expected password (in size and/or content), the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register, and the lock fails.

If the password is previously set (PWD\_LEN is not 0), the card is locked automatically after power-on reset. An attempt to lock a locked card or to lock a card that does not have a password fails and the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register.

#### Unlocking a card

1. Select a card using CMD7 (SELECT/DESELECT\_CARD), if none is selected previously.
2. Define the block length with CMD16(SET\_BLOCKLEN) to send in the 8-bit card lock/unlock mode, 8-bit PWD\_LEN, and the number of bytes of the new password.
3. Send CMD42(LOCK/UNLOCK) with the appropriate data block size on the data line including the 16-bit CRC. The data block indicates the operation mode (SET\_PWD=1), the length (PWD\_LEN) and the password (PWD).
4. When a password is matched, the card is unlocked and CARD\_IS\_LOCKED is cleared in the SDIO\_STS register. If the password sent does not correspond to the expected password (in size and/or content), the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register, and the lock remains locked.

The unlocking function is valid only for the current power session. The card is locked automatically on the next power-up as long as the PWD field is not cleared.

An attempt to unlock an unlocked card fails and the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register.

### Forcing erase

If the user forgot the password (PWD content), it is possible to access the card after clearing all the data on the card. This forced erase operation will erase all card data and all password data.

1. Select a card using CMD7 (SELECT/DESELECT\_CARD), if none is selected previously
2. Define the block length with CMD16(SET\_BLOCKLEN) to send in the 8-bit card lock/unlock mode, 8-bit PWD\_LEN, and the number of bytes of the new password.
3. Send CMD42(LOCK/UNLOCK) with the appropriate data block size on the data line including the 16-bit CRC. The data block indicates the operation mode (ERASE =1). All other bits must be zero.
4. When the ERASE bit is the only bit in the data field, all card content will be erased, including the PWD and the PWD\_LEN field, and the card is no longer locked. When any other bits are not zero, the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register, and the card data are retained, and the card remains locked.

An attempt to force erase an unlocked card fails and the LOCK\_UNLOCK\_FAILED error bit is set in the SDIO\_STS register.

## 25.3.2 Commands and responses

### 25.3.2.1 Commands

#### Command types

Four commands are available to control the SD memory card:

1. Broadcast command: sent to all cards, no responses returned
2. Broadcast command with response: sent to all cards, responses received from all cards simultaneously
3. Addressed command: sent to the selected card, and no data transfer on the SDIO\_D line
4. Addressed data transfer command: sent to the selected card, and data transfer is present on the SDIO\_D line

#### Command description

The SDIO host module system is designed to provide a standard interface for a variety of application types. In the meantime, specific customer/application features must also be taken into account. Because of this, two types of general commands are defined in the standard: general commands (GEN\_CMD) and application-specific commands (ACMD).

To use the application-specific commands, the SDIO host must send CMD55(APP\_CMD) first, and waits the response from the card, which indicates that the APP\_CMD bit is set and an ACMD is expected, before sending ACMD.

Table 25-2 Commands

| CMD index | Type | Parameter                           | Response format | Abbreviation        | Description                                                                      |
|-----------|------|-------------------------------------|-----------------|---------------------|----------------------------------------------------------------------------------|
| CMD0      | bc   | [31: 0]=stuff bits                  | -               | GO_IDLE_STATE       | Reset all cards to idle state                                                    |
| CMD1      | bc   | [31: 0]=OCR                         | R3              | SEND_OP_COND        | In idle state, request a card to send OCR register content through the CMD bus   |
| CMD2      | bcr  | [31: 0]=stuff bits                  | R2              | ALL_Send_CID        | Request all cards to send CID data through the CMD bus                           |
| CMD3      | bcr  | [31: 0]=stuff bits                  | R6              | SEND_RELATIVE_ADDR  | Request a card to issue a new relative card address                              |
| CMD4      | bc   | [31: 16]=DSR<br>[15: 0]= stuff bits | -               | SET_DSR             | Set the DSR register of all cards                                                |
| CMD5      | bcr  | [31: 24]Reserved<br>[23: 0] I/O OCR | R4              | IO_SEND_OP_C<br>OND | Used only for the SDI/O card to query the voltage range of the required I/O card |

|            |      |                                                                                                                  |     |                      |                                                                                                                                                                                                                                       |
|------------|------|------------------------------------------------------------------------------------------------------------------|-----|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD6       | ac   | [31: 26] set to 0<br>[25: 24] access<br>[23: 16] index<br>[15: 8] value<br>[7: 3] set to 0<br>[2: 0] command set | R1b | SWITCH               | Used only for the MMC card to switch the operation modes or modify the EXT_CSD register                                                                                                                                               |
| CMD7       | ac   | [31: 16]=RCA<br>[15: 0]= stuff bits                                                                              | R1b | SELECT/DESELECT_CARD | This command is used to switch a card between the standby state and the send state, or between the programmed and the disconnected state. The relative card address is used to select a card. Address 0 is used to deselect the card. |
| CMD8 (SD)  | bcr  | [31: 12] Reserved<br>[11: 8] operating voltage (VHS)<br>[7: 0] check mode                                        | R7  | SEND_IF_COND         | Send the host power supply voltage to the SD card and check whether the card supports the voltage or not.                                                                                                                             |
| CMD8 (MMC) | adtc | [31: 0]= stuff bits                                                                                              | R1  | SEND_EXT_CSD         | Used only for the MMC card to send its own EXT_CSD register as a data block                                                                                                                                                           |
| CMD9       | ac   | [31: 16]=RCA<br>[15: 0]= stuff bits                                                                              | R2  | SEND_CSD             | The selected card sends CSD (card-specific data) through the CMD bus                                                                                                                                                                  |
| CMD10      | ac   | [31: 16]=RCA<br>[15: 0]= stuff bits                                                                              | R2  | SEND_CID             | The selected card sends CID (card flag) through the CMD bus                                                                                                                                                                           |
| CMD12      | ac   | [31: 0]= stuff bits                                                                                              | R1b | STOP_TRANSMISSION    | Force the card to stop transmission                                                                                                                                                                                                   |
| CMD13      | ac   | [31: 16]=RCA<br>[15: 0]= stuff bits                                                                              | R1  | SEND_STATUS          | Selected card send status register                                                                                                                                                                                                    |
| CMD15      | ac   | [31: 16]=RCA<br>[15: 0]= stuff bits                                                                              | -   | GO_INACTIVE_STATE    | Selected card switch to inactive state                                                                                                                                                                                                |

Table 25-3 Data block read commands

| CMD index | Type | Parameter                 | Response format | Abbreviation        | Description                                                                                                              |
|-----------|------|---------------------------|-----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------|
| CMD16     | ac   | [31: 0]=data block length | R1              | SET_BLOCKLEN        | This command is used to set the length of data blocks (in bytes) for all block commands. The default value is 512 bytes. |
| CMD17     | adtc | [31: 0]=data address      | R1              | READ_SINGLE_BLOCK   | Read a data block of the size set by CMD16                                                                               |
| CMD18     | adtc | [31: 0]=data address      | R1              | READ_MULTIPLE_BLOCK | Continuously read data from the card to the host until the STOP_TRANSMISSION is received                                 |

Table 25-4 Data stream read/write commands

| CMD index | Type | Parameter               | Response format | Abbreviation         | Description                                                                                           |
|-----------|------|-------------------------|-----------------|----------------------|-------------------------------------------------------------------------------------------------------|
| CMD11     | adtc | [31: 0]= data addressR1 |                 | READ_DAT_UNTIL_STOP  | Read data stream form the card starting from a given address until the STOP_TRANSMISSION is received. |
| CMD20     | adtc | [31: 0]= data addressR1 |                 | WRITE_DAT_UNTIL_STOP | Read data stream form the host starting from a given address until the STOP_TRANSMISSION is received. |

Table 25-5 Data block write commands

| CMD index | Type | Parameter                                      | Response format | Abbreviation         | Description                                                                                                              |
|-----------|------|------------------------------------------------|-----------------|----------------------|--------------------------------------------------------------------------------------------------------------------------|
| CMD16     | ac   | [31: 0]=data block length                      |                 | SET_BLOCKLEN         | This command is used to set the length of data blocks (in bytes) for all block commands. The default value is 512 bytes. |
| CMD23     | ac   | [31: 16]=set to 0<br>[15: 0]=data blockR1 size |                 | SET_BLOCK_COUNT      | Define the number of blocks to be transferred in the data block read/write that follows                                  |
| CMD24     | adtc | [31: 0]=data address R1                        |                 | WRITE_BLOCK          | Write a data block of the size set by the CMD16                                                                          |
| CMD25     | adtc | [31: 0]=data address R1                        |                 | WRITE_MULTIPLE_BLOCK | Continuously write data blocks until the STOP_TRANSMISSION is received                                                   |
| CMD26     | adtc | [31: 0]= stuff bits                            | R1              | PROGRAM_CID          | Program the card identification register                                                                                 |
| CMD27     | adtc | [31: 0]= stuff bits                            | R1              | PROGRAM_CSD          | Program the programmable bits of the CSD                                                                                 |

Table 25-6 Block-based write protect commands

| CMD index | Type | Parameter                          | Response format | Abbreviation    | Description                                                                                                                                                                                          |
|-----------|------|------------------------------------|-----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD28     | ac   | [31: 0]= data addressR1b           |                 | SET_WRITE_PROT  | If the card has write protection features, this command sets the write protection bit of the specified group. The properties of write protection are placed in the card-specific area (WP_GRP_SIZE). |
| CMD29     | ac   | [31: 0]= data addressR1b           |                 | CLR_WRITE_PROT  | If the card has write protection features, this command clears the write protection bit of the specified group.                                                                                      |
| CMD30     | adtc | [31: 0]=write protect data address | R1              | SEND_WRITE_PROT | If the card has write protection features, this command asks the card to send the status of the write protection bits.                                                                               |

Table 25-7 Erase commands

| CMD index | Type | Parameter               | Response format    | Abbreviation | Description                                                                                                                            |
|-----------|------|-------------------------|--------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------|
| CMD32     |      |                         |                    |              | Reserved. These command indexes cannot be used in order to maintain backward compatibility with older versions of the MultiMedia card. |
| ...       |      |                         |                    |              |                                                                                                                                        |
| CMD34     |      |                         |                    |              |                                                                                                                                        |
| CMD35     | ac   | [31: 0]=data address R1 | ERASE_GROUP _START |              | Sets the address of the first erase group within a range to be selected for erase                                                      |
| CMD36     | ac   | [31: 0]=data address R1 | ERASE_GROUP _END   |              | Sets the address of the last erase group within a continuous range to be selected for erase                                            |
| CMD37     |      |                         |                    |              | Reserved. These command indexes cannot be used in order to maintain backward compatibility with older versions of the MultiMedia card. |
| CMD38     | ac   | [31: 0]=stuff bits      | R1b                | ERASE        | Erase all previously selected data blocks                                                                                              |

Table 25-8 I/O mode commands

| CMD index | Type | Parameter                                                                                       | Response format | Abbreviation | Description                                                                                                                                                                                                                                                                                                                             |
|-----------|------|-------------------------------------------------------------------------------------------------|-----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD39     | ac   | [31: 16]=RCA<br>[15]=register write flag<br>[14: 8]=register R4 address<br>[7: 0]=register data |                 | FAST_IO      | Used to write and read 8-bit (register) data fields. The command specifies a card and a register and provides the data for writing if the write flag is set. The R4 response contains data read from the specified register. This command accesses application-specific registers that are not defined in the MultiMedia card standard. |
| CMD40     | bcr  | [31: 0]=stuff bits                                                                              | R5              | GO_IRQ_STATE | Place the system in the interrupt mode                                                                                                                                                                                                                                                                                                  |

Table 25-9 Card lock commands

| CMD index | Type | Parameter          | Response format | Abbreviation | Description                                                                                     |
|-----------|------|--------------------|-----------------|--------------|-------------------------------------------------------------------------------------------------|
| CMD42     | adtc | [31: 0]=stuff bits | R1              | LOCK_UNLOCK  | Sets/clears the password or locks/unlocks the card. The size of the data block is set by CMD16. |

Table 25-10 Application-specific commands

| CMD index             | Type | Parameter                          | Response format | Abbreviation | Description                                                                                                                                                                                                   |
|-----------------------|------|------------------------------------|-----------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMD55                 | ac   | [31: 16]=RCA<br>[15: 0]=stuff bits | R1              | APP_CMD      | Indicates to the card that the next command is an application-specific command rather than a standard command.                                                                                                |
| CMD56                 | adtc | [31: 1]=stuff bits<br>[0]=RD/WR    | R1              | GEN_CMD      | Used either to transfer a data block to the card or to read a data block from the card for general-purpose/application-specific commands. The size of the data block is defined by the SET_BLOCK_LEN command. |
| CMD57<br>...<br>CMD59 |      | Reserved.                          |                 |              |                                                                                                                                                                                                               |
| CMD60<br>...<br>CMD63 |      | Reserved for manufacturer          |                 |              |                                                                                                                                                                                                               |

### 25.3.2.2 Response formats

All responses are sent via the CMD bus. The response transmission always starts with the left bit of the bit string corresponding to the response code word. The length depends on the response type.

A response always starts with a start bit (always 0), followed by the transmission bit indicating the direction of transmission (card =0). A value denoted by – in the tables below stands for a variable entry. All responses, except the R3 response type, are protected by a CRC. Every command code word is terminated with the end bit (always 1).

#### 25.3.2.2.1 R1 (normal response command)

Code length = 48 bits. The 45:40 bits indicate the index of the command to be responded to. This value is interpreted as a binary-coded number (between 0 and 63). The status of the card is coded in 32 bits. Note that if it involves a data transfer to a card, a busy signal may appear on the data line after each data block is transmitted. The host should check the busy signal after data block transfer.

Table 25-11 R1 response

| Bit         | 47        | 46               | [45: 40]      | [39: 8]     | [7: 1] | 0       |
|-------------|-----------|------------------|---------------|-------------|--------|---------|
| Field width | 1         | 1                | 6             | 32          | 7      | 1       |
| Value       | 0         | 0                | -             | -           | -      | 1       |
| Description | Start bit | Transmission bit | Command index | Card status | CRC7   | End bit |

#### 25.3.2.2.2 R1b

It is the same as R1 with an optional busy signal transmitted on the data line. The card may become busy after receiving these commands based on its state prior to the command reception. The host should check the busy signal.

#### 25.3.2.2.3 R2 (CID & CSD registers)

Code length = 136 bits. The contents of the CID register are sent as a response to the CMD2 and CMD10 commands. The contents of the CSD register are sent as a response to the CMD9. Only the bits [127 ... 1] of the CID and CSD are transmitted, and the reserved bit [0] of these registers is replaced with the end bit of the response.

Table 25-12 R2 response

|             |           |                  |               |                     |         |
|-------------|-----------|------------------|---------------|---------------------|---------|
| Bit         | 135       | 134              | [ 133 : 128 ] | [ 127 : 1 ]         | 0       |
| Field width | 1         | 1                | 6             | 127                 | 1       |
| Value       | 1         | 0                | 111111        | -                   | 1       |
| Description | Start bit | Transmission bit | Reserved      | CID or CSD register | End bit |

### 25.3.2.2.4 R3 (OCR register)

Code length = 48 bits. The contents of the OCR register are sent as a response to ACMD41.

Table 25-13 R3 response

|             |           |                  |           |              |          |         |
|-------------|-----------|------------------|-----------|--------------|----------|---------|
| Bit         | 47        | 46               | [45 : 40] | [39: 8]      | [7: 1]   | 0       |
| Field width | 1         | 1                | 6         | 32           | 7        | 1       |
| Value       | 1         | 0                | 111111    | -            | 111111   | 1       |
| Description | Start bit | Transmission bit | Reserved  | OCR register | Reserved | End bit |

### 25.3.2.2.5 R4 (Fast I/O)

Code length = 48 bits. The parameter field contains the RCA of the specified card, the register address to be read out or written to, and its contents.

Table 25-14 R4 response

|             |           |                  |          |         |                  |                        |
|-------------|-----------|------------------|----------|---------|------------------|------------------------|
| Bit         | 47        | 46               | [45: 40] | [39: 8] | [7: 1]           | 0                      |
| Field width | 1         | 1                | 6        | 16      | 8                | 8                      |
| Value       | 1         | 0                | 100111   | -       | -                | -                      |
| Description | Start bit | Transmission bit | CMD39    | RCA     | Register address | Read register contents |

### 25.3.2.2.6 R4b

For SD I/O only, an SDIO card will respond with a unique SDIO response R4 after receiving the CMD5.

Table 25-15 R4b response

|             |           |        |          |            |                         |                |
|-------------|-----------|--------|----------|------------|-------------------------|----------------|
| Bit         | 47        | 46     | [45: 40] | [39: 8]    | [7: 1]                  | 0              |
| Field width | 1         | 1      | 6        | 1          | 3                       | 1              |
| Value       | 1         | 0      | -        | -          | -                       | -              |
| Description | Start bit | Tx bit | Res.     | Card ready | Number of I/O functions | Current memory |

### 25.3.2.2.7 R5 (interrupt request)

For MultiMedia card only. Code length = 48 bits. If the response is generated by the host, the RCA field in the parameter will be 0x0.

Table 25-16 R5 response

|             |           |           |          |                                                |                                            |              |
|-------------|-----------|-----------|----------|------------------------------------------------|--------------------------------------------|--------------|
| Bit         | 47        | 46        | [45: 40] | [39: 8]                                        | [7: 1]                                     | 0            |
| Field width | 1         | 1         | 6        | 16                                             | 16                                         | 7            |
| Value       | 1         | 0         | 101000   | -                                              | -                                          | -            |
| Description | Start bit | Start bit | Tx bit   | RCA[31:16] of a successful card or of the host | Not defined. Maybe used for interrupt data | CRC7 End bit |

### 25.3.2.2.8 R6 (interrupt request)

For SD I/O card only. This is a normal response to CMD3 by a memory device.

Table 25-17 R6 response

| Bit         | 47        | 46     | [45: 40] |                                                      | [39: 8]     | [7: 1] | 0       |
|-------------|-----------|--------|----------|------------------------------------------------------|-------------|--------|---------|
| Field width | 1         | 1      | 6        | 16                                                   | 16          | 7      | 1       |
| Value       | 1         | 0      | 000011   | -                                                    | -           | -      | 1       |
| Description | Start bit | Tx bit | CMD3     | RCA[31:16]<br>of a successful<br>card or of the host | Card status | CRC7   | End bit |

The card status bit [23: 8] will be changed when the CMD3 is sent to an I/O-only card. In this case, the 16 bits of response are the SD I/O-only values.

- Bit 15=COM\_CRC\_ERROR
- Bit 14=ILLEGAL\_COMMAND
- Bit 13=ERROR
- Bit [12: 0]=Reserved

### 25.3.3 SDIO functional description

SDIO consists of four parts:

- SDIO adapter block: contains a control unit, command path and data path that provides all functions specific to the MMC/SD/SD I/O card such as the clock generation, command and data transfer
  - Control unit: manages and generates clock signals
  - Command path: manages command transfer
  - Data path: manages data transfer
- AHB interface: generates interrupt and DMA request signals
- Adapter register: system register
- BUF: used for data transfer

Figure 25-6 SDIO block diagram



### 25.3.3.1 SDIO adapter

**SDIO\_CK** is a clock to the MultiMedia/SD/SDIO card provided by the host. One bit of command or data is transferred on both command and data lines with each clock cycle. The clock frequency can vary between different cards and different protocols.

- MultiMedia card
  - V3.31 protocol 0 – 20MHz
  - V4.0/4.2 protocol 0 – 50MHz
- SD card
  - 0 – 50MHz
- SD I/O card
  - 0 – 50MHz

**SDIO\_CMD** is a bidirectional command channel and used for the initialization of a card and command transfer. When the host sends a command to a card, the card will issue a response to the host. The SDIO\_CMD has two operational modes:

- Open-drain mode for initialization (only for MMCV3.31 or previous)
- Push-pull mode for command transfer (SD/SD I/O card and MMC V4.2 also use push-pull drivers for initialization )

**SDIO\_D [7:0]** is a bidirectional data channel. After initialization, the host can change the width of the data bus. After reset, the SDIO\_D0 is used for data transfer by default. MMCV3.31 or previous supports only one bit of data line, so only SDIO\_DO can be used.

The table below is used for the MultiMedia card/SD/SD I/O card bus:

Table 25-18 SDIO pin definitions

| Pin          | Direction     | Description                                                                                  |
|--------------|---------------|----------------------------------------------------------------------------------------------|
| SDIO_CK      | Output        | MultiMedia card/SD/SDIO card clock. This pin is the clock from the host to a card.           |
| SDIO_CMD     | Bidirectional | MultiMedia card/SD/SDIO card command. This pin is the bidirectional command/response signal. |
| SDIO_D[7: 0] | Bidirectional | MultiMedia card/SD/SDIO card data. This pin is the bidirectional databus.                    |

#### Control unit

The control unit consists of a power management sub-unit and a clock management sub-unit. The power management subunit is controlled by the SDIO\_PWRCTRL register. The PS bit is used to define power-up/power-off state. During the power-off and power-up phases, the power management subunit will disable the card bus output signals. The clock management subunit is controlled by the SDIO\_CLKCTRL

register where the CLKDIV bit is used to define the divider factor between the SDIOCLK and the SDIO output clock. If BYPSEN = 0, the SDIO\_CK output signal is driven by the SDIOCLK divided according to the CLKDIV bit; if BYPSEN = 1, the SDIO\_CK output signal is directly driven by the SDIOCLK. The HFCEN is set to enable hardware flow control feature in order to avoid the occurrence of an error at transmission underflow or reception overflow. The PWRSVEN bit can be set by software to enable power save mode, and the SDIO\_CK can be output only when the bus is active.

### Command path

The command path unit sends commands to and receives responses from the cards. When the CCSMEN bit is set in the SDIO\_CMDCTRL register, a command transfer starts. First sends a command to a card by the SDIO\_CMD, the command length is 48 bits. The data on the SDIO\_CMD is synchronized with the rising edge of the SDIO\_CK. A block of data is transferred with each SDIO\_CK, including start bit, transfer bit, command index defined by the SDIO\_CMDCTRL\_CMDIDX bit, parameters defined by the SDIO\_ARG, 7-bit CRC and end bit. Then receives responses from the card. There are two response types: 48-bit short response and 136-bit long response. Both use CRC error check. The received responses are saved in the area from SDIO\_RSP1 to SDIO\_RSP4. The command path can generate command flag, which can be defined by the SDIO\_STS register.

Table 25-19 Command formats

| Bit         | 47        | 46     | [45: 40]      | [39: 8]   | [7: 1] | 0       |
|-------------|-----------|--------|---------------|-----------|--------|---------|
| Width       | 1         | 1      | 6             | 32        | 7      | 1       |
| Value       | 0         | 1      | -             | -         | -      | 1       |
| Description | Start bit | Tx bit | Command index | Parameter | CRC7   | End bit |

Response: A response is sent from a specified card to the host (or synchronously from all cards for MMCV3.31 or previous), as an answer to a previously received command. Responses are transferred serially on the CMD line.

Table 25-20 Short response format

| Bit         | 47        | 46     | [45: 40]      | [39: 8]   | [7: 1]            | 0       |
|-------------|-----------|--------|---------------|-----------|-------------------|---------|
| Width       | 1         | 1      | 6             | 32        | 7                 | 1       |
| Value       | 0         | 0      | -             | -         | -                 | 1       |
| Description | Start bit | Tx bit | Command index | Parameter | CRC7 (or 1111111) | End bit |

Table 25-21 Long response format

| Bit         | 135       | 134 | [133: 128] | [127: 1]                             | 0       |
|-------------|-----------|-----|------------|--------------------------------------|---------|
| Width       | 1         | 1   | 6          | 127                                  | 1       |
| Value       | 0         | 0   | 111111     | -                                    | 1       |
| Description | Start bit | Tx  | Reserved   | CID or CSD (including internal CRC7) | End bit |

Table 25-22 Command path status flags

| Flag       | Description                                        |
|------------|----------------------------------------------------|
| CMDRSPCMPL | A response is already received (CRC OK)            |
| CMDFAIL    | A command response is already received (CRC fails) |
| CMDCMPL    | A command is sent (does not require a response)    |
| CMDTIMEOUT | Command response timeout (64 SDIO_CK cycles)       |
| DOCMD      | Command transfer is in progress                    |

## Command channel state machine (CCSM)

When the CCSMEN bit is set in the SDIO\_CMDCTR register, command transfer starts. When the command has been sent, the command channel state machine (CCSM) will set the status flags and enters the idle state if a response is not required. When a response is received, the received CRC code and the internally generated CRC code are compared, and the appropriate status flags are set.

- The CCSM remains in the idle state for at least 8 SDIO\_CK cycles to meet the Ncc (the minimum delay between two host commands) and NRC (the minimum delay between the host command and the card response).
- When the wait state is entered, the command timer is enabled. If the NCR timeout (response time to a command), that is, 64 SDIO\_CK periods, is reached before the CCSM moves to the receive state, the timeout flag is set (CMDTIMEOUT) and the idle state is entered.

If the interrupt bit is set in the command register, the timer is disabled and the CCSM waits for an interrupt request from one card. If the pending bit is set in the command register, the CCSM will enter pend state and wait for a CmdPend signal from the data path subunit. When detecting the CmdPend, the CCSM goes to the send state, which triggers the data counter to send the stop command.

Figure 25-7 Command channel state machine (CCSM)



Figure 25-8 SDIO command transfer



### Data channel

The data path subunit transfers data between the host and the cards. The databus width can be configured using the BUSWS bit in the SDIO\_CLKCTRL register. By default, only the SDIO\_DO signal line is used for transfer. Only one bit of data is transferred with each clock cycle. If the 4-bit wide bus mode is selected, four bits are transferred per clock cycle over the SDIO\_D [3:0] signal line. If the 8-bit wide bus mode is selected, eight bits are transferred per clock cycle over the SDIO\_D [7: 0] signal line. The TFRDIR bit is set in the SDIO\_DTCTR register to define the transfer direction. If TFRDIR=0, it indicates that the data is transferred from the controller to the card; if TFRDIR=1, it indicates that the data is transferred from the card to the controller. The TFRMODE bit can be used to select block data transfer or stream transfer for the MultiMedia card. If the TFREN bit is set, data transfer starts. Depending on the TFRDIR bit, the DCSM enters Wait\_S or Wait\_R state.

### Data channel state machine (DCSM)

The DCSM has seven states, in send and receive mode, as shown in the Figure below:

Figure 25-9 Data channel state machine (DCSM)



#### Send mode

- **Idle:** The data channel is inactive, either in the Wait\_S or the Wait\_R state.
- **Wait\_S:** Waits until the BUF flag becomes empty or the data transmission is completed. The DCSM must remain in the Wait\_S state for at least two clock periods to meet the N<sub>WR</sub> timing requirements where the N<sub>WR</sub> is the interval between the reception of the card response and the start of the data transfer from the host.
- **Send:** The DCSM sends data to a card, and the data transfer mode can be either block or stream, depending on the SDIO\_DTCTRL\_TFRMODE bit. If an overflow error occurred, the DCSM then moves to the idle state

- Busy: The DCSM waits for the CRC flag. If the DCSM receives a correct CRC status and is not busy, it will enter the Wait\_S state. If it does not receive a correct CRC status or a timeout occurs while the DCSM is in the busy state, a CRC fail flag or timeout flag is generated.
- Wait\_R: The start bit of the Wait\_R. If a timeout occurs before it detects a start bit, the DCSM moves to the idle state and generates a timeout flag.
- Receive: Data is received from a card and written to the BUF. The data transfer mode can be either block or stream, depending on the SDIO\_DTCTRL\_TFRMODE bit. If an overflow error occurs, it then returns to Wait\_R state.

Table 25-23 Data token formats

| Description | Start bit | Data | CRC16 | End bit |
|-------------|-----------|------|-------|---------|
| Block data  | 0         | -    | Y     | 1       |
| Stream data | 0         | -    | N     | 1       |

### 25.3.3.2 Data BUF

The data BUF contains a transmit and receive unit. It is a 32-bit wide and 32-word deep data buffer. Because the data BUF operates in the AHB clock domain (HCLK), all signals connected to the SDIO clock domain (SDIOCLK) are resynchronized.

- Transmit BUF: Data can be written to the transmit BUF via the AHB interface when the SDIO transmission feature is enabled.

The transmit BUF has 32 sequential addresses. It contains a data output register that holds the data word pointed by the read pointer. When the data path has loaded its shift register, it moves its read pointer to the next data and outputs data.

If the transmit BUF is disabled, all status flags are inactive. The data path sets the DOTX when it transmits data.

- Receive BUF: When the data path receives a data word, it will write the data to the BUF. The write pointer is incremented automatically after the end of the write operation. On the other side, a read pointer always points to the current data in the BUF. If the receive BUF is disabled, all status flags are cleared, and the read and write pointers are reset as well. The data path sets the DORX when it receives data.

### 25.3.3.3 SDIO AHB interface

The AHB interface generates the interrupt and DMA requests, and access the SDIO interface registers and the data BUF.

#### SDIO interrupts

The interrupt logic generates an interrupt request when one of the selected status flags is high. The SDIO\_INTEN register is used to select the conditions that will generate an interrupt.

#### SDIO/DMA interface: data transfer process between the SDIO and memory

In the following examples, data is transferred from the host to the card. The SDIO BUF is filled with data stored in a memory through the DMA controller.

1. Card identification process
2. Increase the SDIO\_CK frequency
3. Select a card by sending CMD7
4. Enable the DMA2 controller and clear all interrupt flag bits, configure the DMA2 channel4 source address register as the memory buffer's base address, and the DMA2 channel4 destination address register as the SDIO\_BUF register address. Then configure the DMA2 channel4 control register (memory increment, non-peripheral increment, and peripheral and source data width is word width). Finally enable DMA2 channel4.
5. Send CMD24 (WRITE\_BLOCK) as follows:

Program the SDIO data length register (SDIO\_DTLEN), the BLKSIZE bit in the SDIO data control register (SDIO\_DTCTRL), and the SDIO parameter register (SDIO\_ARG) with the address of the card where data is to be transferred, and program the SDIO command register (SDIO\_CMD), enable the CCSMEN bit, wait for SDIO\_STS [6]=CMDRSPCMPL interrupt,

and then program the SDIO data control register (SDIO\_DTCTRL): TFREN=1 (enable the SDIO card host to send data), TFRDIR=0 (from the controller to the card), TFRMODE=0 (block data transfer), DMAEN=1 (enable DMA), BLKSIZE=9 (512 bytes), and wait from SDIO\_STS [10]=DTBLKCMPL.

6. Check that no channels are still enabled by confirming the DMA channel enable SDIO status register (SDIO\_STS)

#### 25.3.3.4 Hardware flow control

The HFCEN bit is set in the SDIO\_CLKCTRL register to enable hardware flow control, which is used to avoid BUF underflow and overflow errors. Read/write access to the BUF is still active even if flow control is enabled.

### 25.3.4 SDIO I/O card-specific operations

The SDIO can support the following operations (except read suspend, for it does not require specific hardware operation) when the SDIO\_DTCTRL [11] is set.

#### SDIO read wait operation by SDIO\_D2 signal lines

The optional read wait operation is used only for SD card 1-bit or 4-bit mode. The read wait operation can instruct the host to stop data transfer temporarily while the host is reading from multiple registers (IO\_RW\_EXTENDED, CMD53), and also allows the host to send commands to other functions in the SD I/O device in order to start a read wait process after the reception of the first data block. The detailed process as follows:

- Enable data path (SDIO\_DTCTRL [0] = 1)
- Enable SDIO-specific operation (SDIO\_DTCTRL [11] = 1)
- Start read wait (SDIO\_DTCTRL [10]=0 and SDIO\_DTCTRL [8]=1)
- Data direction is from a card to the SDIO host (SDIO\_DTCTRL [1]=1)
- The data unit in the SDIO adapter will enter read wait state, and drive the SDIO\_D2 to 0 after 2 SDIO\_CK cycles
- The data unit starts waiting to receive data from a card. The DCSM will not enter read wait even if read wait start is set. The read wait process will start after the CRC is received. The RDWTSTOP has to be cleared to start a new read wait operation.

During the read wait period, the SDIO host can detect the SDIO interrupts over the SDIO\_D1.

#### SDIO read wait operation by stopping clock

If the SDIO card does not support the mentioned above read wait operation, the SDIO can enter a read wait by stopping SDIO\_CK, described as follows:

- Enable data path (SDIO\_DTCTRL [0] = 1)
- Enable SDIO-specific operation (SDIO\_DTCTRL [11] = 1)
- Start read wait (SDIO\_DTCTRL [10]=0 and SDIO\_DTCTRL [8]=1)

The DCSM stops the clock two SDIO\_CK cycles after the end bit of the current received data block and starts the clock again after the read wait end bit is set.

Note that as the SDIO\_CK is stopped, the SDIO host cannot send any command to the card. The SDIO host can detect the SDIO interrupt over the SDIO\_D1.

#### SDIO suspend/resume operation (write and read operation suspend)

To free the bus to provide higher-priority transfers for other functions or memories, the host can suspend data transfer to certain functions or memories. As soon as the higher-priority transfer is completed, the previous transfer operation will restart at the suspended location.

While sending data to a card, the SDIO can suspend the write operation. The SDIO\_CMD [11] bit is set and indicates to the CCSM that the current command is a suspend command. The CCSM analyzes the response and when an ACK signal is received from the card (suspend accepted), it acknowledges the DCSM that enters the idle state after receiving the CRC of the current data block.

### SDIO interrupts

There is a pin with interrupt feature on the SD interface in order to enable the SD I/O card to interrupt the MultiMedia card/SD module. In 4-bit SD mode, this pin is SDIO\_D1. The SD I/O interrupts are detected when the level is active. In other words, the interrupt signal line must be active (low) before it is recognized and responded by the MultiMedia card/SD module, and will remain inactive (high) at the end of the interrupt routine.

When the SDIO\_DTCTRL [11] bit is set, the SDIO interrupts are detected on the SDIO\_D1 signal line.

## 25.4 SDIO registers

The device communicates with the system through 32-bit control registers accessible via AHB.

The peripheral registers must be accessed by words (32-bit).

Table 25-24 A summary of the SDIO registers

| Register     | Offset | Reset value |
|--------------|--------|-------------|
| SDIO_PWRCTRL | 0x00   | 0x0000 0000 |
| SDIO_CLKCTRL | 0x04   | 0x0000 0000 |
| SDIO_ARG     | 0x08   | 0x0000 0000 |
| SDIO_CMD     | 0x0C   | 0x0000 0000 |
| SDIO_RSPCMD  | 0x10   | 0x0000 0000 |
| SDIO_RSP1    | 0x14   | 0x0000 0000 |
| SDIO_RSP2    | 0x18   | 0x0000 0000 |
| SDIO_RSP3    | 0x1C   | 0x0000 0000 |
| SDIO_RSP4    | 0x20   | 0x0000 0000 |
| SDIO_DTTMR   | 0x24   | 0x0000 0000 |
| SDIO_DTLEN   | 0x28   | 0x0000 0000 |
| SDIO_DTCTRL  | 0x2C   | 0x0000 0000 |
| SDIO_DTCNTR  | 0x30   | 0x0000 0000 |
| SDIO_STS     | 0x34   | 0x0000 0000 |
| SDIO_INTCLR  | 0x38   | 0x0000 0000 |
| SDIO_INTEN   | 0x3C   | 0x0000 0000 |
| SDIO_BUFCNTR | 0x48   | 0x0000 0000 |
| SDIO_BUF     | 0x80   | 0x0000 0000 |

### 25.4.1 SDIO power control register (SDIO\_PWRCTRL)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                       |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 2 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                                                                        |
| Bit 1: 0  | PS       | 0x0         | rw   | Power switch<br>These bits are set or cleared by software. They are used to define the current status of the card clock.<br>00: Power-off, the card clock is stopped.<br>01: Reserved<br>10: Reserved<br>11: Power-on, the card clock is started. |

*Note: Write access to this register is not allowed within seven HCLK clock periods after data is written.*

## 25.4.2 SDIO clock control register (SDIO\_CLKCTRL)

The SDIO\_CLKCTRL register controls the SDIO\_CK output clock.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                    |
| Bit 16: 15 | CLKDIV   | 0x0         | rw   | Clock division<br>This field is set or cleared by software. It defines the clock division relations between the SDIOCLK and the SDIO_CK: SDIO_CK frequency=SDIOCLK / [CLKDIV[9:0] + 2].                                                                                                                                                       |
| Bit 14     | HFCEN    | 0x0         | rw   | Hardware flow control enable<br>This bit is set or cleared by software.<br>0: Hardware flow control disabled<br>1: Hardware flow control enabled<br>Note: When hardware flow control is enabled, refer to the SDIO_STS register for the meaning of the TXBUF_E and RXBUF_F interrupt signals.                                                 |
| Bit 13     | CLKEGS   | 0x0         | rw   | SDIO_CK edge selection<br>This bit is set or cleared by software.<br>0: SDIO_CK generated on the rising edge of the master clock SDIOCLK<br>1: SDIO_CK generated on the falling edge of the master clock SDIOCLK                                                                                                                              |
| Bit 12: 11 | BUSWS    | 0x0         | rw   | Bus width selection<br>This bit is set or cleared by software.<br>00: Default bus mode, SDIO_D0 used<br>01: 4-bit bus mode, SDIO_D[3: 0] used<br>10: 8-bit bus mode, SDIO_D[7: 0] used                                                                                                                                                        |
| Bit 10     | BYPSEN   | 0x0         | rw   | Clock divider bypass enable bit<br>This bit is set or cleared by software. When disabled, the SDIO_CK output signal is driven by the SDIOCLK that is divided according to the CLKDIV value. When enabled, the SDIO_CK output signal is directly driven by the SDIOCLK.<br>0: Clock divider bypass disabled<br>1: Clock divider bypass enabled |
| Bit 9      | PWRSVEN  | 0x0         | rw   | Power saving mode enable<br>This bit is set or cleared by software. When disabled, the SDIO_CK is always output; when enabled, the SDIO_CK is only output when the bus is active.<br>0: Power saving mode disabled<br>1: Power saving mode enabled                                                                                            |
| Bit 8      | CLKOEN   | 0x0         | rw   | Clock output enable<br>This bit is set or cleared by software.<br>0: Clock output disabled<br>1: Clock output enabled                                                                                                                                                                                                                         |
| Bit 7: 0   | CLKDIV   | 0x00        | rw   | Clock division<br>This field is set or cleared by software. It defines the clock division relations between the SDIOCLK and the SDIO_CK: SDIO_CK frequency=SDIOCLK / [CLKDIV[9:0] + 2].                                                                                                                                                       |

**Note:**

1. While the SD/SDIO card or MultiMedia card is in identification mode, the SDIO\_CK frequency must be less than 400kHz.
2. When all card are assigned with relative card addresses, the clock frequency can be changed to the maximum card frequency.
3. This register cannot be written within seven HCLK clock periods after data is written. The SDIO\_CK can be stopped during the read wait period for SD I/O cards. In this case, the SDIO\_CLKCTRL register does not control the SDIO\_CK.

### 25.4.3 SDIO argument register (SDIO\_ARG)

The SDIO\_ARG register contains 32-bit command argument, which is sent to a card as part of a command.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                            |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | ARGU | 0x0000 0000 | rw   | Command argument<br>Command argument is sent to a card as part of a command. If a command contains an argument, it must be loaded into this register before writing a command to the command register. |

### 25.4.4 SDIO command register (SDIO\_CMD)

The SDIO\_CMD register contains the command index and command type bits. The command index is sent to a card as part of a command. The command type bits control the command channel state machine (CCSM).

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                       |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                        |
| Bit 11     | IOSUSP   | 0x0         | rw   | SD I/O suspend command<br>This bit is set or cleared by software. If this bit is set, the command to be sent is a suspend command (used for SDIO only).<br>0: SD I/O suspend command disabled<br>1: SD I/O suspend command enabled                                |
| Bit 10     | CCSMEN   | 0x0         | rw   | Command channel state machine (CCSM) enable bit<br>This bit is set or cleared by software.<br>0: Command channel state machine disabled<br>1: Command channel state machine enabled                                                                               |
| Bit 9      | PNDWT    | 0x0         | rw   | CCSM Waits for ends of data transfer (CmdPending internal signal)<br>This bit is set or cleared by software. If this bit is set, the CCSM waits for the end of data transfer before it starts sending a command.<br>0: Disabled<br>1: Enabled                     |
| Bit 8      | INTWT    | 0x0         | rw   | CCSM waits for interrupt request<br>This bit is set or cleared by software. If this bit is set, the CCSM disables command timeout and waits for an interrupt request.<br>0: Disabled<br>1: Enabled                                                                |
| Bit 7: 6   | RSPWT    | 0x0         | rw   | Wait for response bits<br>This bit is set or cleared by software. This bit indicates whether the CCSM is to wait for a response, and if yes, it will indicate the response type.<br>00: No response<br>01: Short response<br>10: No response<br>11: Long response |
| Bit 5: 0   | CMDIDX   | 0x00        | rw   | Command index<br>The command index is sent to a card as part of a command.                                                                                                                                                                                        |

*Note:* 1. This register cannot be written within seven HCLK clock periods after data is written.

2. MultiMedia card can send two types of responses: 48-bit short response or 136-bit short response. The SD card and SD I/O card can send only short responses, and the argument can vary according to the type of response. The software will distinguish the type of response according to the command sent.

## 25.4.5 SDIO command response register (SDIO\_RSPCMD)

The SDIO\_RSPCMD register contains the command index of the last command response received. If the command response transmission does not contain the command index (long or OCR response), the SDIO\_RSPCMD field is unknown, although it should have contained 111111b (the value of the reserved field from a response)

| Bit       | Name     | Reset value | Type | Description                                                                                       |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------|
| Bit 31: 6 | Reserved | 0x00000000  | resd | Kept at its default value.                                                                        |
| Bit 5: 0  | RSPCMD   | 0x00        | ro   | Response command index<br>This field contains the command index of the command response received. |

## 25.4.6 SDIO response 1..4 register (SDIO\_RSPx)

The SDIO\_RSPx (x=1..4) register contains the status of a card, which is part of the response received.

| Bit       | Name     | Reset value | Type | Description                                                                                |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------|
| Bit 31: 0 | CARDSTSx | 0x0000 0000 | ro   | See Table 23-25<br>The card status size is 32 or 127 bits, depending on the response type. |

Table 25-25 Response type and SDIO\_RSPx register

| Register  | Short response      | Long response         |
|-----------|---------------------|-----------------------|
| SDIO_RSP1 | Card status [31: 0] | Card status [127: 96] |
| SDIO_RSP2 | Unused              | Card status [95: 64]  |
| SDIO_RSP3 | Unused              | Card status [63: 32]  |
| SDIO_RSP4 | Unused              | Card status [31: 1]   |

The most significant bit of the card status is always received first. The least significant bit of the SDIO\_RSP4 register is always 0.

## 25.4.7 SDIO data timer register (SDIO\_DTTMR)

The SDIO\_DTTMR register contains the data timeout period in the unit of card bus clock periods. A counter loads the value from the SDIO\_DTTMR register and starts decrementing when the DCSM enters the Wait\_R or busy state. If the counter reaches 0 while the DCSM is in either of these states, a timeout status flag will be set.

| Bit       | Name    | Reset value | Type | Description                                                          |
|-----------|---------|-------------|------|----------------------------------------------------------------------|
| Bit 31: 0 | TIMEOUT | 0x0000 0000 | rw   | Data timeout period<br>Data timeout period in card bus clock cycles. |

*Note: A data transfer must be written to the SDIO\_DTCNTR and the SDIO\_DTLEN register before being written to the SDIO data control register (SDIO\_DTCTRL).*

## 25.4.8 SDIO data length register (SDIO\_DTLEN)

The SDIO\_DTLEN register contains the number of data bytes to be transferred. The value is loaded into the data counter when data transfer starts.

| Bit        | Name     | Reset value | Type | Description                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------|
| Bit 31: 25 | Reserved | 0x00        | resd | Kept at its default value.                                   |
| Bit 24: 0  | DTLEN    | 0x00000000  | rw   | Data length value<br>Number of data bytes to be transferred. |

*Note: For a block data transfer, the value in the SDIO\_DTLEN must be a multiple of the block data size.*

*A data transfer must be written to the SDIO\_DTCNTR and the SDIO\_DTLEN register before being written to the SDIO data control register (SDIO\_DTCTRL).*

## 25.4.9 SDIO data control register (SDIO\_DTCTRL)

The SDIO\_DTCTRL register controls the data channel status machine (DCSM).

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 12 | Reserved  | 0x00000     | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 11     | IOEN      | 0x0         | rw   | SD I/O enable functions<br>This bit is set or cleared by software. If the bit is set, the DCSM performs an SD IO card-specific operation.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 10     | RDWTMODE  | 0x0         | rw   | Read wait mode<br>This bit is set or cleared by software. If disabled, the SDIO_D2 controls the read wait; if enabled, the SDIO_CK controls the read wait.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 9      | RDWTSTOP  | 0x0         | rw   | Read wait stop<br>This bit is set or cleared by software. While the RDWTSTART is set, If this bit is set, it indicates that read wait is stopped; if this bit cleared, it indicates that the read wait is in progress.<br>0: Read wait is in progress if the RDWTSTART is set.<br>1: Read wait is stopped if the RDWTSTART is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 8      | RDWTSTART | 0x0         | rw   | Read wait start<br>This bit is set or cleared by software. When this bit is set, read wait starts; when this bit is cleared, no actions occurs.<br>0: Read wait disabled<br>1: Read wait enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 7: 4   | BLKSIZE   | 0x0         | rw   | Data block size<br>This bit is set or cleared by software. This field defines the length of data block when the block data transfer is selected.<br>0000: block length = $2^0$ = 1 byte<br>0001: block length = $2^1$ = 2 bytes<br>0010: block length = $2^2$ = 4 bytes<br>0011: block length = $2^3$ = 8 bytes<br>0100: block length = $2^4$ = 16 bytes<br>0101: block length = $2^5$ = 32 bytes<br>0110: block length = $2^6$ = 64 bytes<br>0111: block length = $2^7$ = 128 bytes<br>1000: block length = $2^8$ = 256 bytes<br>1001: block length = $2^9$ = 512 bytes<br>1010: block length = $2^{10}$ = 1024 bytes<br>1011: block length = $2^{11}$ = 2048 bytes<br>1100: block length = $2^{12}$ = 4096 bytes<br>1101: block length = $2^{13}$ = 8192 bytes<br>1110: block length = $2^{14}$ = 16384 bytes<br>1111: Reserved |
| Bit 3      | DMAEN     | 0x0         | rw   | DMA enable bit<br>This bit is set or cleared by software.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bit 2      | TFRMODE   | 0x0         | rw   | Data transfer mode selection<br>This bit is set or cleared by software. If this bit is set, it indicates stream data transfer; if this bit cleared, it indicates block data transfer.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 1      | TFRDIR    | 0x0         | rw   | Data transfer direction selection<br>This bit is set or cleared by software. If this bit is set, data transfer is from a card to a controller; if this bit is cleared, data transfer is from a controller to a card.<br>0: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|       |       |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 0 | TFREN | 0x0 | rw | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |       |     |    | Data transfer enabled bit<br>This bit is set or cleared by software. If this bit is set, data transfer starts. The DCSM enters the Wait_S or Wait_R state, depending on the direction bit TFRDIR. The DCSM goes to the read wait state if the RDWTSTART bit is set from the beginning of the transfer. It is not necessary to clear the enable bit after the end of data transfer but the SDIO_DTCNTL must be updated to enable a new data transfer. |
|       |       |     |    | 0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                            |

*Note: This register cannot be written within seven HCLK clock periods after data is written.*

#### 25.4.10 SDIO data counter register (SDIO\_DTCNTL)

The SDIO\_DTCNTL register loads the value from the SDIO\_DTLEN register when the DCSM moves from the idle state to the Wait\_R or Wait\_S state. During the data transfer, the counter value decrements to 0, and then the DCSM enters the idle state and sets the data status end flag bit DTCMPL.

| Bit        | Name     | Reset value | Type | Description                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 25 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                          |
| Bit 24: 0  | CNT      | 0x00000000  | ro   | Data count value<br>When this register is read, the number of data bytes to be transferred is returned. Write access has no effect. |

*Note: This register can be read only when the data transfer is complete.*

#### 25.4.11 SDIO status register (SDIO\_STS)

The SDIO\_STS is a read-only register, containing two types of flags:

- Static flags (bits [23: 22, 10: 0]): These bits can be cleared by writing to the SDIO\_INTCLR register.
- Dynamic flags (bit [21: 11]): These bit status changes with the state of the corresponding logic (for example, BUT full or empty flag is set or cleared as data written to the BUF).

| Bit        | Name       | Reset value | Type | Description                                                                                                                  |
|------------|------------|-------------|------|------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved   | 0x000       | resd | Kept at its default value.                                                                                                   |
| Bit 22     | IOIF       | 0x0         | ro   | SD I/O interrupt received                                                                                                    |
| Bit 21     | RXBUF      | 0x0         | ro   | Data available in receive BUF                                                                                                |
| Bit 20     | TXBUF      | 0x0         | ro   | Data available in transmit BUF                                                                                               |
| Bit 19     | RXBUFE     | 0x0         | ro   | Receive BUF empty                                                                                                            |
| Bit 18     | TXBUFE     | 0x0         | ro   | Transmit BUF empty<br>If hardware flow control is enabled, the TXBUF_E signal becomes valid when the BUF contains two words. |
| Bit 17     | RXBUFF     | 0x0         | ro   | Receive BUF full<br>If hardware flow control is enabled, the RXBUF_F becomes valid two words before the BUF is full.         |
| Bit 16     | TXBUFF     | 0x0         | ro   | Transmit BUF full                                                                                                            |
| Bit 15     | RXBUFFH    | 0x0         | ro   | Receive BUF half full<br>There are at least 8 words in the BUF. This flag bit can be used as DMA request.                    |
| Bit 14     | TXBUFH     | 0x0         | ro   | Transmit BUF half empty:<br>At least 8 words can be written to the BUF. This flag bit can be used as DMA request.            |
| Bit 13     | DORX       | 0x0         | ro   | Data receive in progress                                                                                                     |
| Bit 12     | DOTX       | 0x0         | ro   | Data transmit in progress                                                                                                    |
| Bit 11     | DOCMD      | 0x0         | ro   | Command transfer in progress                                                                                                 |
| Bit 10     | DTBLKCMPL  | 0x0         | ro   | Data block sent/received CRC check passed)                                                                                   |
| Bit 9      | SBITERR    | 0x0         | ro   | Start bit not detected on all data signals in wide bus mode                                                                  |
| Bit 8      | DTCMPL     | 0x0         | ro   | Data end (data counter, SDIO CNT, is zero)                                                                                   |
| Bit 7      | CMDCMPL    | 0x0         | ro   | Command sent (no response required)                                                                                          |
| Bit 6      | CMDRSPCMPL | 0x0         | ro   | Command response (CRC check passed)                                                                                          |
| Bit 5      | RXERRO     | 0x0         | ro   | Received BUF overrun error                                                                                                   |

|       |            |     |    |                                                                                               |
|-------|------------|-----|----|-----------------------------------------------------------------------------------------------|
| Bit 4 | TXERRU     | 0x0 | ro | Transmit BUF underrun error                                                                   |
| Bit 3 | DTTIMEOUT  | 0x0 | ro | Data timeout                                                                                  |
| Bit 2 | CMDTIMEOUT | 0x0 | ro | Command response timeout<br>The command timeout is a fixed value of 64 SDIO_CK clock periods. |
| Bit 1 | DTFAIL     | 0x0 | ro | Data block sent/received (CRC check failed)                                                   |
| Bit 0 | CMDFAIL    | 0x0 | ro | Command response received (CRC check failed)                                                  |

### 25.4.12 SDIO clear interrupt register (SDIO\_INTCLR)

The SDIO\_INTCLR is a read-only register. Writing 1 to the corresponding register bit will clear the correspond bit in the SDIO\_STS register.

| Bit        | Name       | Reset value | Type | Description                                                                            |
|------------|------------|-------------|------|----------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved   | 0x000       | resd | Kept at its default value.                                                             |
| Bit 22     | IOIF       | 0x0         | rw   | SD I/O interface flag clear bit<br>This bit is set by software to clear the IOIF flag. |
| Bit 21: 11 | Reserved   | 0x000       | resd | Kept at its default value.                                                             |
| Bit 10     | DTBLKCMPL  | 0x0         | rw   | DTBLKCMPL flag clear bit<br>This bit is set by software to clear the DTBLKCMPL flag.   |
| Bit 9      | SBITERR    | 0x0         | rw   | SBITERR flag clear bit<br>This bit is set to clear the SBITERR flag.                   |
| Bit 8      | DTCMPL     | 0x0         | rw   | DTCMPL flag clear bit<br>This bit is set by software to clear the DTCMPL flag.         |
| Bit 7      | CMDCMPL    | 0x0         | rw   | CMDCMPL flag clear bit<br>This bit is set by software to clear the CMDCMPL flag.       |
| Bit 6      | CMDRSPCMPL | 0x0         | rw   | MDRSPCMPL flag clear bit<br>This bit is set by software to clear the CMDRSPCMPL flag.  |
| Bit 5      | RXERRO     | 0x0         | rw   | RXERRO flag clear bit<br>This bit is set by software to clear the RXERRO flag.         |
| Bit 4      | TXERRU     | 0x0         | rw   | TXERRU flag clear bit<br>This bit is set by software to clear the TXERRU flag.         |
| Bit 3      | DTTIMEOUT  | 0x0         | rw   | DTTIMEOUT flag clear bit<br>This bit is set by software to clear the DTTIMEOUT flag.   |
| Bit 2      | CMDTIMEOUT | 0x0         | rw   | CMDTIMEOUT flag clear bit<br>This bit is set by software to clear the CMDTIMEOUT flag. |
| Bit 1      | DTFAIL     | 0x0         | rw   | DTFAIL flag clear bit<br>This bit is set by software to clear the DTFAIL flag.         |
| Bit 0      | CMDFAIL    | 0x0         | rw   | CMDFAIL flag clear bit<br>This bit is set by software to clear the CMDFAIL flag.       |

### 25.4.13 SDIO interrupt mask register (SDIO\_INTEN)

The SDIO\_INTEN register determines which status bit generates an interrupt by setting the corresponding bit.

| Bit        | Name       | Reset value | Type | Description                                                                                                                                                                 |
|------------|------------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 23 | Reserved   | 0x000       | resd | Kept at its default value.                                                                                                                                                  |
| Bit 22     | IOIFIEN    | 0x0         | rw   | SD I/O mode received interrupt enable<br>This bit is set or cleared by software to enable/disable the SD I/O mode received interrupt function.<br>0: Disabled<br>1: Enabled |
| Bit 21     | RXBUIFIEN  | 0x0         | rw   | Data available in RxBUF interrupt enable<br>This bit is set or cleared by software to enable/disable the Data Available in RxBUF Interrupt.<br>0: Disabled<br>1: Enabled    |
| Bit 20     | TXBUIFIEN  | 0x0         | rw   | Data available in TxBUF interrupt enable<br>This bit is set or cleared by software to enable/disable the Data Available in TxBUF Interrupt.<br>0: Disabled<br>1: Enabled    |
| Bit 19     | RXBUEFEIEN | 0x0         | rw   | RxBUF empty interrupt enable<br>This bit is set or cleared by software to enable/disable the                                                                                |

|        |               |     |    |                                                                                                                                                                    |
|--------|---------------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |               |     |    | RxBUF empty interrupt.<br>0: Disabled<br>1: Enabled                                                                                                                |
| Bit 18 | TXBUFEIEN     | 0x0 | rw | TxBUF empty interrupt enable<br>This bit is set or cleared by software to enable/disable the TxBUF empty interrupt.<br>0: Disabled<br>1: Enabled                   |
| Bit 17 | RXBUFFIEN     | 0x0 | rw | RxBUF full interrupt enable<br>This bit is set or cleared by software to enable/disable the RxBUF full interrupt.<br>0: Disabled<br>1: Enabled                     |
| Bit 16 | TXBUFFIEN     | 0x0 | rw | TxBUF full interrupt enable<br>This bit is set or cleared by software to enable/disable the TxBUF full interrupt.<br>0: Disabled<br>1: Enabled                     |
| Bit 15 | RXBUFHIEN     | 0x0 | rw | RxBUF half full interrupt enable<br>This bit is set or cleared by software to enable/disable the RxBUF half full interrupt.<br>0: Disabled<br>1: Enabled           |
| Bit 14 | TXBUFHIEN     | 0x0 | rw | TxBUF half empty interrupt enable<br>This bit is set or cleared by software to enable/disable the TxBUF half empty interrupt.<br>0: Disabled<br>1: Enabled         |
| Bit 13 | DORXIEN       | 0x0 | rw | Data receive acting interrupt enable<br>This bit is set or cleared by software to enable/disable the Data receive acting interrupt.<br>0: Disabled<br>1: Enabled   |
| Bit 12 | DOTXIEN       | 0x0 | rw | Data transmit acting interrupt enable<br>This bit is set or cleared by software to enable/disable the Data transmit acting interrupt.<br>0: Disabled<br>1: Enabled |
| Bit 11 | DOCMDIEN      | 0x0 | rw | Command acting interrupt enable<br>This bit is set or cleared by software to enable/disable the Command acting interrupt.<br>0: Disabled<br>1: Enabled             |
| Bit 10 | DTBLKCMPLIEN  | 0x0 | rw | Data block end interrupt enable<br>This bit is set or cleared by software to enable/disable the Data block end interrupt.<br>0: Disabled<br>1: Enabled             |
| Bit 9  | SBITERRIEN    | 0x0 | rw | Start bit error interrupt enable<br>This bit is set or cleared by software to enable/disable the Start bit error interrupt.<br>0: Disabled<br>1: Enabled           |
| Bit 8  | DTCMPLIEN     | 0x0 | rw | Data end interrupt enable<br>This bit is set or cleared by software to enable/disable the Data end interrupt.<br>0: Disabled<br>1: Enabled                         |
| Bit 7  | CMDCMPLIEN    | 0x0 | rw | Command sent interrupt enable<br>This bit is set or cleared by software to enable/disable the Command sent interrupt.<br>0: Disabled<br>1: Enabled                 |
| Bit 6  | CMDRSPCMPLIEN | 0x0 | rw | Command response received interrupt enable                                                                                                                         |

|       |               |     |    |                                                                                                                                                                    |
|-------|---------------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |               |     |    | This bit is set or cleared by software to enable/disable the Command response received interrupt.<br>0: Disabled<br>1: Enabled                                     |
| Bit 5 | RXERROIEN     | 0x0 | rw | RxBUF overrun error interrupt enable<br>This bit is set or cleared by software to enable/disable the RxBUF overrun error interrupt.<br>0: Disabled<br>1: Enabled   |
| Bit 4 | TXERRUIEN     | 0x0 | rw | TxBUF underrun error interrupt enable<br>This bit is set or cleared by software to enable/disable the TxBUF underrun error interrupt.<br>0: Disabled<br>1: Enabled |
| Bit 3 | DTTIMEOUTIEN  | 0x0 | rw | Data timeout interrupt enable<br>This bit is set or cleared by software to enable/disable the Data timeout interrupt.<br>0: Disabled<br>1: Enabled                 |
| Bit 2 | CMDTIMEOUTIEN | 0x0 | rw | Command timeout interrupt enable<br>This bit is set or cleared by software to enable/disable the Command timeout interrupt.<br>0: Disabled<br>1: Enabled           |
| Bit 1 | DTFAILIEN     | 0x0 | rw | Data CRC fail interrupt enable<br>This bit is set or cleared by software to enable/disable the Data CRC fail interrupt.<br>0: Disabled<br>1: Enabled               |
| Bit 0 | CMDFAILIEN    | 0x0 | rw | Command CRC fail interrupt enable<br>This bit is set or cleared by software to enable/disable the Command CRC fail interrupt.<br>0: Disabled<br>1: Enabled         |

#### 25.4.14 SDIOBUF counter register (SDIO\_BUFCNTR)

The SDIO\_BUFCNTR register contains the number of words to be written to or read from the BUF. The BUF counter loads the value from the SDIO\_DTLEN register when the data transfer bit TFREN is set in the SDIO\_DCTRL register. If the data length is not word-aligned, the remaining 1 to 3 bytes are regarded as a word.

| Bit        | Name     | Reset value | Type | Description                                            |
|------------|----------|-------------|------|--------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at its default value.                             |
| Bit 23: 0  | CNT      | 0x000000    | ro   | Number of words to be written to or read from the BUF. |

#### 25.4.15 SDIO data BUF register (SDIO\_BUF)

The receive and data BUF is group of a 32-bit wide registers that can be written or read. The BUF contains 32 registers on 32 sequential addresses. The CPU can use BUF for read/write multiple operations.

| Bit       | Name | Reset value | Type | Description                                                                                                                   |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | DT   | 0x0000 0000 | rw   | Receive and transmit BUF data<br>The BUF data occupies 32x 32-bit words, the address:<br>SDIO base + 0x80 to SDIO base + 0xFC |

# 26 Ethernet media access control (EMAC)

This module applies only to AT32F437 series, not including AT32F435 series.

## 26.1 EMAC introduction

Copyright Synopsys, Inc. All rights reserved.

The Ethernet peripheral enables the AT32F437 to transmit and receive data (10/100Mbps) through Ethernet in compliance with IEEE 802.3-2002 standard.

The AT32F437 Ethernet peripheral supports two standard interfaces to the external PHY: media independent interface (MII) defined in the IEEE 802.3 standard and the reduced media independent interface (RMII).

### 26.1.1 EMAC structure

Figure 26-1 Block diagram of EMAC



### 26.1.2 EMAC main features

The Ethernet peripheral contains an EMAC core and a DMA controller. The transmission and reception of the frame is scheduled by DMA.

#### DMA features

- Programmable AHB burst transfer types
- Supports ring or chained descriptor
- Each descriptor can transfer up to 8 KB of data
- Poll or fixed-priority arbitration between transmission and reception
- Programmable interrupts for different operational conditions
- Status information report for each transfer

#### EMAC core features

- Supports 10/100Mbps data transfer rates
- IEEE 802.3-compliant MII interface to communicate with an external high-speed Ethernet PHY
- Supports flow control for full-duplex operation, and CSMA/CD protocol for half-duplex operations
- Automatic CRC and pad generation controllable on transmission frames
- Automatically remove pad bits/CRC on reception frames
- Programmable frame length up to 16 KB
- Programmable frame gap (40-96 bits)
- Supports a variety of address filtering modes and promiscuous modes
- Supports IEEE 802.1Q VLAN tag detection for reception frames
- Supports mandatory network statistics with RMON/MIB counters (RFC2819/RFC2665)
- Detection of LAN remote wakeup frames and AMD Magic Packet™ frames

- Supports checking IPv4 header checksum and IPv4, TCP, UDP or ICMP (packaged in IPv4 or IPv6 data formats) checksum
- Supports Ethernet frame time stamp as defined in IEEE 1588-2008. 64-bit time stamps are recorded in the transmit or receive status
- Two 2 KB FIFOs: one for transmit, and one for receive with a configurable threshold
- Filter received error frames and not forward them to the application in store-forward mode
- Supports store-forward mechanism for data transfer to the MAC controller
- Discard frames on late collision, excessive collisions, excessive deferral and underflow conditions
- Clear FIFO by software
- Calculates and inserts IPv4 header checksum and TCP, UDP or ICMP checksum in frames transmitted in store-forward mode
- Supports loopback mode on the MII interface for debugging
- Programmable time stamps of receive and transmit frames as defined in IEEE 1588-2008 standard
- Supports two correction methods: coarse and fine correction
- Second pulse output (programmable)
- Trigger interrupts when the system is greater than the specified time

## 26.2 EMAC functional description

The Ethernet peripheral consists of a MAC 802.3 (media access controller), MII interface and a dedicated DMA controller.

It implements the following functions:

- Data transmit and receive
  - Framing (frame boundary and frame synchronization)
  - Handling of source and destination addresses
  - Error detection
- Media access management in half-duplex mode
  - Medium allocation (avoid collision)
  - Collision resolve (handle collision)

Usually there are two operating modes for the MAC sublayer:

- Half-duplex mode: The stations compete for the use of the physical medium using the CSMA/CD algorithm. Two stations can only communicate in a single transfer direction at the same time.
- Full-duplex mode: CSMA/CD algorithm is unnecessary, but the following conditions must be met:
  - Physical medium supports simultaneous transmission and reception
  - Only two stations connected to the LAN
  - Both two stations configured as full-duplex mode

### 26.2.1 EMAC communication interfaces

The EMAC allows to configure the station management interface (SMI) of PHY, media-independent interface (MII) for Ethernet frame communication, and reduced media-independent interface RMII.

#### Station management interface (SMI)

The PHY management interface (SMI) accesses PHY registers through a clock and data line. It supports up to 32 PHYs.

MDC: PHY configures clock signals, at the maximum frequency of 2.5 MHz. The minimum high and low times for MDC must be 160ns, and the minimum period is 400ns. In idle state, the MDC clock signal remains low.

MDIO: Bidirectional port, data input/output lines.

Figure 26-2 SMI interface signals



Before write operation, PHY address, MII register and EMAC\_MACMIIADDR register must be configured first, followed by the MII MW and MB bits, and then the SMI interface will transfer the PHY address, PHY register address and data to the PHY. During the transaction, the contents of the EMAC\_MACMIIADDR and the EMAC\_MACMIIIDT registers are not allowed to change.

Before read operation, the PHY address and MII register must be configured first, and then the MB bit is set and MW bit is set to 0 in the EMAC\_MACMIIADDR register.

The SMI interface sends the PHY address and PHY register address, and then starts reading the PHY register contents. During the transaction, the MB bit is always set. It is cleared by the SMI interface at the end of read operation. Attention should be paid to the fact that the contents of the EMAC\_MACMIIADDR and EMAC\_MACMIIIDT registers are not allowed to change (The application should not change these register contents. After the transaction, the EMAC\_MACMIIIDT register is automatically updated with the data read from the SMI).

The SMI clock source is a divided AHB clock. The divide factor depends on the AHB clock frequency. Note that the divide factor must be configured correctly since the MDC frequency must not be greater than 2.5 MHz.

Table 26-1 shows the clock range.

| Selection bit | AHB clock  | MDC clock     |
|---------------|------------|---------------|
| 0000          | 60~100MHz  | AHB clock/42  |
| 0001          | 100~150MHz | AHB clock/62  |
| 0010          | 20~35MHz   | AHB clock/16  |
| 0011          | 35~60MHz   | AHB clock/26  |
| 0100          | 150~250MHz | AHB clock/102 |
| 0101          | 250~288MHz | AHB clock/124 |
| 0110,0111     | Reserved   | --            |

#### Media-independent interface: MII

The media-independent interface (MII) acts an interconnection between the MAC sublayer and the PHY for data transfer at 10Mbit/s and 100Mbit/s.

Figure 26-3 MII signals



MII\_TX\_CLK: Transmit data clock signal. This clock is 2.5MHz at 10Mbps speed; 25MHz at 100Mbps speed.

MII\_RX\_CLK: Receive data clock signal. This clock is 2.5MHz at 10Mbps speed; 25MHz at 100Mbps speed.

MII\_TX\_EN: Transmit enable signal. It must be set synchronously with the start bit of the preamble, and must remain asserted until all bits to be transmitted are transmitted.

MII\_TXD[3: 0]: Transmit data. 4-bit data are transmitted each time synchronously. Data is valid when the MII\_TX\_EN signal is active. The MII\_TXD[0] is the least significant bit while the MII\_TXD[3] is the most significant bit.

MII\_CRS: carrier sense signal defined in the CSMA/CD. It is controlled by the PHY and can be valid only in half-duplex mode. This signal is active when either the transmit or receive medium is not idle. The PHY must ensure that the MII\_CS signal remains active throughout the duration of a collision condition. This signal is not required to be synchronized with the TX and RX clocks.

MII\_COL: Collision detection signal defined in CSMA/CD. It is controlled by the PHY and can be valid only in half-duplex mode. This signal is enabled upon detection of a collision on the medium and will remain enabled during the duration of the collision. This signal is not required to be synchronized with the TX and RX clocks.

MII\_RXD[3: 0]: It is controlled by the PHY. Four-bit data to be received are transmitted synchronously. Data is valid when the MII\_RX\_DV signal is active. The MII\_RXD[0] is the least significant bit, while the MII\_RXD[3] is the most significant bit. While the MII\_RX\_DV is inactive but the MII\_RX\_ER is active, the PHY will transmit a specific MII\_RXD[3: 0] value to indicate specific information.

MII\_RX\_DV: Receive data valid signal. It is controlled by the PHY. This signal is valid when the PHY has kept data on the MII for reception. It must be enabled synchronously with the first bit (MII\_RX\_CLK) and must remain enabled until data transfer is fully completed. It must be cleared prior to the first clock following the transmission of the final four-bit data. In order to receive a frame correctly, the MII\_RX\_DV signal must remain valid throughout the frame transmission. The active level must be no later than the SFO bit.

MII\_RX\_ER: Receive error signal. It must be active for one or more clock periods (MII\_RX\_CLK) to indicate to the MAC that an error was detected in a frame. Detailed error information depends on the state of the MII\_RX\_DV and MII\_RXD[3: 0] data.

Table 26-2 Transmit interface signal encode

| MII_TX_EN | MII_TXD[3: 0] | Description           |
|-----------|---------------|-----------------------|
| 0         | 0000 to 1111  | Normal frame interval |
| 1         | 0000 to 1111  | Normal data transfer  |

Table 26-3 Receive interface signal encode

| MII_RX_DV | MII_RX_ER | MII_RXD[3: 0] | Description              |
|-----------|-----------|---------------|--------------------------|
| 0         | 0         | 0000 to 1111  | Normal frame interval    |
| 0         | 1         | 0000          | Normal frame interval    |
| 0         | 1         | 0001 to 1101  | Reserved                 |
| 0         | 1         | 1110          | False carrier indication |
| 0         | 1         | 1111          | Reserved                 |
| 1         | 0         | 0000 to 1111  | Normal data reception    |
| 1         | 1         | 0000 to 1111  | Data reception error     |

### Reduced media-independent interface: RMII

The reduced media-independent interface reduces the pin count between the AT32F437xx Ethernet peripheral and the external Ethernet. According to the IEEE802.3u standard, the MII interface requires 16 pins for data and control signals, while the RMII reduces the pin count to 7 pins (a 62.5% decrease in pin count)

The RMII interface is used to connect the EMAC and the PHY. This helps translate the MAC MII signal to the RMII.

Figure 26-4 Reduced media-independent interface signals



### MII/RMII selection and clock sources

Either the MII or RMII mode can be selected using the 23<sup>rd</sup> bit MII\_RMII\_SEL in the SCFG\_CFG2 register. The MII/RMII mode must be selected when the Ethernet controller is in reset state or before the clock is enabled.

### MII clock sources

The EMAC TX\_CLK and RX\_CLK clock signals are provided by the PHY. External PHY module is driven by an external 25MHz clock, which can be provided by either an oscillator or the MCU CLKOUT pin. Refer to CRM section for more information.

Figure 26-5 MII clock sources (provided by CLKOUT pin)



Figure 26-6 MII clock sources (provided by an external oscillator)



### RMII clock sources

As shown in Figure 26-7, both the EMAC and PHY require 50MHz clock sources, which can be done with an external crystal oscillator.

Figure 26-7 RMII clock sources (provided by an external crystal oscillator)



## EMAC pin allocation and multiplexing

Table 26-4 Ethernet peripheral pin configuration

| EMAC signal       | MII     | RMII    | Pin  | Pin description              |
|-------------------|---------|---------|------|------------------------------|
| EMAC_MDC          | MDC     | MDC     | PC1  | Multiplexed push-pull output |
| EMAC_MII_TXD2     | TXD2    | -       | PC2  | Multiplexed push-pull output |
| EMAC_MII_TX_CLK   | TX_CLK  | -       | PC3  | Floating input (reset state) |
| EMAC_MII_CRS      | CRS     | -       | PA0  | Floating input (reset state) |
| EMAC_MII_RX_CLK   | RX_CLK  | REF_CLK | PA1  | Floating input (reset state) |
| EMAC_RMII_REF_CLK |         |         |      |                              |
| EMAC_MDIO         | MDIO    | MDIO    | PA2  | Multiplexed push-pull output |
| EMAC_MII_COL      | COL     | -       | PA3  | Floating input (reset state) |
| EMAC_MII_RX_DV    | RX_DV   | CRS_DV  | PA7  | Floating input (reset state) |
| EMAC_RMII_CRS_DV  |         |         |      |                              |
| EMAC_MII_RXD0     | RXD0    | RXD0    | PC4  | Floating input (reset state) |
| EMAC_RMII_RXD0    |         |         |      |                              |
| EMAC_MII_RXD1     | RXD1    | RXD1    | PC5  | Floating input (reset state) |
| EMAC_RMII_RXD1    |         |         |      |                              |
| EMAC_MII_RXD2     | RXD2    | -       | PB0  | Floating input (reset state) |
| EMAC_MII_RXD3     | RXD3    | -       | PB1  | Floating input (reset state) |
| EMAC_MII_RX_ER    | RX_ER   | -       | PB10 | Floating input (reset state) |
| EMAC_MII_TX_EN    | TX_EN   | TX_EN   | PB11 | Multiplexed push-pull output |
| EMAC_RMII_TX_EN   |         |         |      |                              |
| EMAC_MII_TXD0     | TXD0    | TXD0    | PB12 | Multiplexed push-pull output |
| EMAC_MII_TXD1     | TXD1    | TXD1    | PB13 | Multiplexed push-pull output |
| EMAC_PPS_OUT      | PPS_OUT | PPS_OUT | PB5  | Multiplexed push-pull output |
| EMAC_MII_TXD3     | TXD3    | -       | PB8  | Multiplexed push-pull output |
| EMAC_RMII_CRS_DV  | RX_DV   | CRS_DV  | PD8  | Floating input (reset state) |
| EMAC_MII_RXD0     | RXD0    | RXD0    | PD9  | Floating input (reset state) |
| EMAC_RMII_RXD0    |         |         |      |                              |
| EMAC_MII_RXD1     | RXD1    | RXD1    | PD10 | Floating input (reset state) |
| EMAC_RMII_RXD1    |         |         |      |                              |
| EMAC_MII_RXD2     | RXD2    | -       | PD11 | Floating input (reset state) |
| EMAC_MII_RXD3     | RXD3    | -       | PD12 | Floating input (reset state) |

### 26.2.2 EMAC frame communication

#### Frame format

Figure 26-8 shows the MAC frame format and tagged MAC frame format (Refer to IEEE 802.C-2002 for more information on MAC frame formats)

Figure 26-8 MAC frame format



Figure 26-9 Tagged MAC frame format

|                     |        |                          |  |
|---------------------|--------|--------------------------|--|
|                     | 7bytes | Preamble                 |  |
|                     | 1byte  | SFD                      |  |
|                     | 6bytes | DA                       |  |
|                     | 6bytes | SA                       |  |
| Qtag Prefix 4 bytes |        | 802.1QTag Type           |  |
|                     |        | Flag control information |  |
|                     | 2bytes | MAC client length/type   |  |
|                     |        | MAC client data          |  |
| 46-1500bytes        |        | PAD                      |  |
|                     | 4bytes | FCS                      |  |

### EMAC frame filtering

EMAC supports source and destination address filtering.

#### Address filtering

Based on frame filtering register chosen by the application, address filtering checks the source and destination addresses over all received frames using the MAC address and multicast HASH table. The address filtering status is reported accordingly.

#### Unicast destination address filter

There are two filtering modes: perfect address filtering and HASH table filtering.

1. Perfect address filtering: It is enabled by setting HUC=0 in the frame filtering register. Four MAC addresses are used for perfect filtering. The MACADDR0 is always enabled. The MACADDR1, MACADDR2 and MACADDR3 bits are enabled using their respective AE bit. The MBC bit in the address register is set to mask the address comparison of the corresponding bytes. If the MBC bit is all 0, the EMAC will compare all 48 bits of the received unicast address with the programmed MAC address, if matched, the unicast address is said to have passed through the filtering.
2. HASH table filtering: The HUC must be set in the frame filtering register. The EMAC performs imperfect filtering for unicast addresses through 64-bit HASH table. For HASH filtering, the MAC calculates the CRC value of the received destination address (see the note below) and uses the 6 upper CRC bits to index the HASH table. A value of 000000 corresponds to bit 0 in the HASH table register, and a value of 111111 corresponds to bit 63 in the HASH table register. If the corresponding bit in the HASH table relative to the CRC value is set to 1, it indicates that the frame has passed through the HASH filter; otherwise, it has failed the HASH filter.

#### Multicast destination address filter

1. The MAC can be programmed to receive all multicast frames by setting PMC=1 in the frame filter register
2. If the PMC is set to 0 and the HMC is set to 0, perfect address filtering can be done using the MACADDR0/1/2/3 addresses.
3. If the PMC is set to 0, and the HMC is set to 1, the 64-bit HASH table is used to perform imperfect filtering.

#### Broadcast address filter

If the DBF is set in the frame filter register, the EMAC will reject all broadcast frames. If DBF=0, the EMAC will accept all broadcast frames.

#### Unicast source address filter

If the bit 30 is set in the MAC address register 1/2/3, the filter will compare source address instead of destination address of the received frames.

If the SAF bit is set in the frame filter address, the frames that failed the SA filter will be dropped by the

EMAC. In this case, the frames that pass through both SA and DA filtering can be forwarded to the application; otherwise, they will be dropped.

### Inverse filtering operation

The DAIF and SAIF bits in the frame filter register are used to invert the filtering output result for both destination and source address filtering. The DAIF bit is applicable for both unicast and multicast destination frames, while the SAIF bit for the unicast source address.

Table 26-5 Destination address filtering

| Frame type | PMC | HPF | HUC | DAIF | HMC | PMC | DBF | DA filter operation                                                         |
|------------|-----|-----|-----|------|-----|-----|-----|-----------------------------------------------------------------------------|
| Broadcast  | 1   | X   | X   | X    | X   | X   | X   | Pass                                                                        |
|            | 0   | X   | X   | X    | X   | X   | 0   | Pass                                                                        |
|            | 0   | X   | X   | X    | X   | X   | 1   | Fail                                                                        |
| Unicast    | 1   | X   | X   | X    | X   | X   | X   | Pass all frames                                                             |
|            | 0   | X   | 0   | 0    | X   | X   | X   | Pass on perfect/group filter match                                          |
|            | 0   | X   | 0   | 1    | X   | X   | X   | Fail on perfect/group filter match                                          |
|            | 0   | 0   | 1   | 0    | X   | X   | X   | Pass on HASH filter match                                                   |
|            | 0   | 0   | 1   | 1    | X   | X   | X   | Fail on HASH filter match                                                   |
|            | 0   | 1   | 1   | 0    | X   | X   | X   | Pass on HASH or perfect/group filter match                                  |
|            | 0   | 1   | 1   | 1    | X   | X   | X   | Fail on HASH or perfect/group filter match                                  |
|            | 1   | X   | X   | X    | X   | X   | X   | Pass all frames                                                             |
| Multicast  | X   | X   | X   | X    | X   | 1   | X   | Pass all frames                                                             |
|            | 0   | X   | X   | 0    | 0   | 0   | X   | Pass on perfect/group filter match and drop PAUSE frames if PCF= 0x         |
|            | 0   | 0   | X   | 0    | 1   | 0   | X   | Pass on HASH filter match and drop PAUSE frames if PCF= 0x                  |
|            | 0   | 1   | X   | 0    | 1   | 0   | X   | Pass on HASH or perfect/group filter match and drop PAUSE frames if PCF= 0x |
|            | 0   | X   | X   | 1    | 0   | 0   | X   | Fail on perfect/group filter match and drop PAUSE frames if PCF= 0x         |
|            | 0   | 0   | X   | 1    | 1   | 0   | X   | Fail on HASH filter match and drop PAUSE frames if PCF= 0x                  |
|            | 0   | 1   | X   | 1    | 1   | 0   | X   | Fail on HASH or perfect/group filter match and drop PAUSE frames if PCF= 0x |

Table 26-6 Source address filtering

| Frame type | PR | SAIF | SAF | SA filter operation                                                          |
|------------|----|------|-----|------------------------------------------------------------------------------|
| Unicast    | 1  | X    | X   | Pass all frames                                                              |
|            | 0  | 0    | 0   | Pass status on perfect/group filter match but do not drop frames that failed |
|            | 0  | 1    | 0   | Fail status on perfect/group filter match but do not drop frames that failed |
|            | 0  | 0    | 1   | Pass on perfect/group filter match and drop frames that failed               |
|            | 0  | 1    | 1   | Fail on perfect/group filter match and drop frames that failed               |

### EMAC frame transmission

The EMAC frame transmission is controlled by the DMA controller and MAC. Once a transmission command is sent by the application, Ethernet frames read from the user data buffer (such as SRAM) are stored into TXFIFO by the DMA. The frames are then popped out and transferred to the MAC core. The MAC core sends the frames to external Ethernet PHY via MII/RMII interface so as to communicate with external stations. When the end-of-frame is transferred, the status of the transmission is generated from the MAC core and transferred back to the DMA controller.

When the SOF is detected, the MAC accepts data and begins transmitting to the MII/RMII. The time required to transmit the data frame to the MII/RMII after the application initiates is variable, due to various delay factors like frame interval, time to transmit preamble/SFD and any back-off delays caused by

CSMA/CD algorithm in half-duplex mode. After the EOF is transferred to the MAC core, the core completes normal transmission and then gives the status of the transmission back to the DMA.

There are two modes of operation for popping data from TXFIFO to the MAC core:

- In threshold mode: If the number of bytes in the FIFO crosses the configured threshold (or when the EOF is written before the threshold is crossed), the data is ready to be popped out and forwarded to the MAC core. The threshold level is configured using the TTC bits in the EMAC\_DMAOPM register.
- In store-and-forward mode: Only after a complete frame is written to the FIFO, the data is transferred to the MAC core. If the TXFIFO size is smaller than the Ethernet frame to be transmitted, then the data is also transferred to the MAC core when the TXFIFO becomes almost full.

The FTF bit (the bit 20 in the EMAC\_DMAOPM register) can be set to flush the TXFIFO. If the FTF bit is mistakenly set in the middle of transferring a frame to the MAC core, the FIFO is flushed and the frame transmission is aborted. An underflow event is marked in the EMAC transmitter and the corresponding status is given to the DMA core.

### Automatic CRC and pad generation

If the length of a transmitting frame is less than 46 bytes, the minimum data size for an Ethernet frame defined in IEEE802.3 standard, the EMAC can be programmed to append padding (zeroes are appended) automatically so that zeroes are appended to the transmitting frame to make the data length exactly 46 bytes.

During a frame transmission, the EMAC can be programmed either to append CRC to the frame check sequence or not to append CRC. When the EMAC is programmed to append pads for frames (DA+SA+LT+Data) less than 60 bytes, the CRC value will be appended at the end of the padded frames.

### Collision detection in CSMA/CD

The collision detection is applicable only to half-duplex mode, not to full-duplex mode (refer to Ethernet protocol for more information).

In MII mode, if a collision occurs at any time from the beginning of a frame to the end of the CRC, the collision signal is sent to the EMAC core. The EMAC core will send a 32-bit jam signal of 0x5555 5555 to inform all other stations on the LAN that a collision has occurred. If the collision happened during the preamble transmission phrase, the EMAC completes the transmission of the preamble and SFD and then sends the jam signal.

### Jabber timer

The EMAC jabber timer is enabled (set EMAC\_MACCTRL[20]=0) to prevent certain station on the LAN from occupying the LAN for a long time. Once enabled, the EMAC will stop transmitting if the application tries to send a frame more than 2048 bytes.

### Interframe gap management

The EMAC enables transmission after satisfying the interframe gap and backoff delays. The MAC maintains an idle period of the programmed interframe gap (IFG bits in the EMAC\_MACCTRL register) between any two transmitted frames. The EMAC starts its IFG counter as soon as the carrier signal of the MII becomes inactive. If a frame arrives sooner than the configured IFG time, it will be delayed for transmission until the interframe time is reached. The MAC starts its IFG counter as soon as the carrier signal of the MII becomes inactive. In full-duplex mode, the MAC enables transmission at the end of the configured IFG value. In half-duplex mode, if the IFG is configured as 96 bit times, the MAC will follow the rule defined in Section 4.2.3.2.1 of the IEEE 802.3 specification. The MAC will reset its IFG counter if a carrier is detected during the first two-thirds of the IFG interval (64-bit times). If the carrier is detected during the final one-third of the IFG interval, the MAC will continue the IFG count and enables transmission after the IFG interval is reached. In half-duplex mode the MAC follows the truncated binary exponential backoff algorithm.

### Transmit flow control

In full-duplex mode the EMAC implements Transmit flow control using pause frames. The EMAC can request the suspension of the frame transmission by sending Pause frames in two ways.

When the FCB bit in the EMAC\_MACFCTRL register is set, the EMAC generates and transmits a single Pause frame. The value of the pause time in the generated frame holds the programmed pause time

value in the EMAC\_MACFCTRL register. To extend the pause time or cancel the remaining pause time, the EMAC must send another pause frame (PT=0 will cancel the remaining pause time).

If flow control is enabled (EFT=1 in the EMAC\_MACFCTRL register), when the RXFIFO is full, the EMAC generates and transmits a Pause time. If the RXFIFO remains full while the programmed pause time threshold is satisfied, the MAC will transmit another Pause frame. The process is repeated as long as the receive FIFO remains full. If the RXFIFO is not full prior to the pause time, the MAC transmits a Pause time with zero pause time to indicate to the remote station that the receive buffer is ready to receive new data frames.

### Retransmission during collision

When a frame is being transferred to the MAC, a collision event may occur on the MAC line in half-duplex mode. The MAC would then try retransmission even before the end of the frame is received. At this point, if retransmission is enabled, the frame is popped out again from the FIFO. After 96 bytes have been popped towards the MAC core, the FIFO controller will release that space to allow the DMA to push in more data. This means that the retransmission is not possible if this threshold (96 bytes) is crossed or when the MAC core indicates a late collision event.

### Transmit FIFO flush operation

The FTF bit (bit 20) in the EMAC\_DMAOPM register is set to flush TXFIFO. The TXFIFO flush operation is immediate and the corresponding points are reset to their initial states even if the TXFIFO is in the process of transferring a frame to the MAC core. This operation will abort the current frame transmission and result in an underflow event in the EMAC. The status of such a frame is generated (TDES0 bits 1 and 13). The flush operation is completed when the application (DMA) has received all of the status words of the frames that were flushed. Then the FTF bit is cleared in the EMAC\_DMAOPM register. In this case, TXFIFO is allowed to receive new frames from the application (DMA). All data that do not start with an SOF marker will be discarded after the flush operation.

### Transmit status word and time stamp

At the EMAC controller has completed the transmission of the Ethernet frame, the transmit status is given to the application. If IEEE 1588 time stamp is enabled, a 64-bit time stamp, along with the transmit status, will be written to the transmit descriptor.

### Transmit checksum offload

The most widespread use of Ethernet is to encapsulate TCP or UDP over IP datagrams, so the Ethernet controller has a transmit checksum feature that supports checksum calculation and insertion in the transmit path, and error detection in the receive path.

*Note: This function is enabled only when the TXFIFO is configured as store-and-forward mode (that is, when the TSF is set in the EMAC\_DMAOPM register). If the TXFIFO depth is less than the input Ethernet frame size, the checksum function is invalid and only the IPv4 header checksum is calculated and modified by the EMAC, even in store-and-forward mode.*

See IETF specifications RFC791, RFC 793, RFC 768, RFC 792, RFC 2460 and RFC 4443 for IPv4, TCP, UDP, ICMP, IPv6 and ICMPv6 specifications.

#### IP header checksum

The checksum module will detect an IPv4 datagrams when the Ethernet frame's type field has the value of 0x0800 and the IP datagram's version field has the value of 0x4. The input frame's checksum field is ignored and replaced by the calculated value. IPv6 headers do not have a checksum field, thus the checksum module does not modify IPv6 header fields. The result of this IP header checksum calculation is indicated by the IP header error status bit (TDES0 bit 16). This status bit is set whenever the values of the Ethernet type field and the IP header's version field are not consistent, or when the Ethernet frame does not have enough data. In other words, this bit is set when the following errors occurred.

- For IPv4 datagrams
  - The received Ethernet type is 0x0800, but the IP header's version field is not equal to 0x4
  - The IPv4 header length field has a value less than 0x5 (20 bytes)
  - The total frame length is less than the value given in the IPv4 header length field
- For IPv6 datagrams
  - The received Ethernet type is 0x86DD, but the IP header's version field is not equal to 0x6

- The frame ends before the IPv6 header (40 bytes) or extension header (including header length field) has been completely received. Even if the checksum module detects such an IP header error, it inserts an IPv4 header checksum if the Ethernet type field indicates an IPv4 payload.

#### TCP/UDP/ICMP checksum

The TCP/UDP/ICMP checksum determines whether the encapsulated data is TCP, UDP or ICMP by analyzing the IPv4 or IPv6 header (including extension headers).

- Note:**
1. For non-TCP, - UDP or - ICMP/ICMPv6 data, this checksum function is invalid and the frame data is not modified.
  2. Fragmented IP frames (IPv4 or IPv6), IP frames with security features (such as an authentication header or encapsulated security data) and IPv6 frames with routing headers are not processed by the checksum.

The checksum is calculated for the TCP, UDP or ICMP data and inserted into its corresponding field in the header. It can work in the following two modes:

1. The TCP, UDP or ICMPv6 pseudo-header is not included in the checksum calculation and is assumed to be present in the input frame's checksum field. The checksum field is included in the checksum calculation, and then replaced by the final calculated checksum.
2. The checksum field is ignored, and the TCP, UDP or ICMPv6 pseudo-header data are included into the checksum calculation, and the checksum field is overwritten with the final calculated value.

The result of this operation is indicated by the checksum error status bit in the transmit status vector (TDES0 bit 12). The data checksum error status bit is set when either of the following is detected:

1. The frame has been forwarded to the MAC transmitter in store-and-forward mode without the end of the frame being written to the TXFIFO.
2. The packet ends before the number of bytes indicated by the data length field in the IP header is received.

When the packet is longer than the indicated data length, the bytes are ignored as stuff bytes, and no error is reported. When the first type of error is detected, the TCP, UDP or ICMP header is not modified. For the second type of error, the calculated checksum is still inserted into the corresponding header field.

#### EMAC frame reception

The MAC received frames are stored into the RXFIFO and sent out by the DMA using the AHB interface. There are two modes: Cut-through mode and store-and-forward mode.

In the default Cut-through mode, when the frame data length greater than the programmed threshold (configured with the RTC bit in the EMAC\_DMAOPM register) or a full packet of data are received in the RXFIFO, the data are popped out and the DMA is notified of its availability. The DMA will keep popping out the data from the RXFIFO until the data transfer is completed. Upon completion of the EOF frame transfer, the status word is popped out and sent to the DMA controller.

In store-and-forward mode (configured by the RSF bit in the EMAC\_DMAOPM register), a frame is read by the DMA only after being written completely into the RXFIFO.

If the EMAC core is configured to drop all error frames, behavior varies in different reception modes:

1. In store-and-forward mode, only the valid frames are read and forwarded to the application by the DMA.
2. In Cut-through mode, some error frames are not dropped because the error status is received at the end of the frame.

A reception operation is initiated when the EMAC detects an SFD on the MII. The MAC core strips the preamble and SFD before processing the frame. The header fields are checked for the filtering and the FCS field used to verify the CRC of the frame. The frame is dropped in the core if it failed the address filter.

If IEEE1588 time stamping is enabled, a snapshot of the system time is taken when any frame's SFD is detected on the MII. This time stamp is passed onto the application when the EMAC has completed the current frame.

If the received frame length/type field is less than 0x600 and if the EMAC is configured for the auto

CRC/pad stripping option, the EMAC sends the data of the frame to RXFIFO up to the count specified in the length/type field, then starts dropping bytes (including the FCS field). If the length/type field is greater than 0x600, the MAC sends all received Ethernet frame data to RXFIFO, regardless of the value on the programmed auto-CRC strip option.

The EMAC watchdog timer is enabled by default, frames above 2048 bytes (DA + SA + LT + Data + pad + FCS) are cut off. This feature can be disabled by the WD bit in the EMAC\_MACCTRL register. However, even if the watchdog timer is disabled, frame length greater than 16 KB are cut off and a watchdog timeout event is reported.

### Receive checksum offload

Both IPv4 and IPv6 frames are detected for data integrity by setting the IPC bit in the EMAC\_MACCTRL register. The EMAC identifies IPv4 or IPv6 frames by checking for the Ethernet type field value. The receive checksum offload calculates IPv4 header checksums and checks that they match the received IPv4 header checksums. The result of the header checksum is indicated by the bit 7 of the receive descriptor (RDES0). The IP header error bit is set either one of the following conditions:

1. Ethernet type field does not match the IP header version field
2. Received frames are less than the length indicated by the IPv4 header length field
3. IPv4 or IPv6 headers less than 20 bytes

The receive checksum offload also identifies a TCP, UDP or ICMP payload in the received IP datagrams (IPv4 or IPv6) and calculates the checksum of such payloads properly, as defined in the TCP, UDP or ICMP specifications. It includes the TCP/UDP/ICMPv6 pseudo-header bytes for checksum calculation and the result of CRC is indicated by the bit 0 in the receive descriptor (RDES0). This bit is set either one of the following conditions:

1. Received TCP, UDP or ICMP data length does not match that of the IP headers
2. The calculated checksum does not equal the value of the TCP, UDP or ICMP checksum field

### Receive flow control

In Full-duplex mode, the MAC detects the receiving Pause frame and pauses the frame transmission according to the delay specified within the received Pause frame.

The ERF bit in the EMAC\_MACFCTRL register to enable or disable Pause frame detection function. Once receive flow control is enabled, the EMAC will decode the Pause frames.

During the pause period, if another Pause frame is detected with a zero Pause time value, the MAC clears the PAUSE time and retransmits the data. If it is not a zero Pause time value, the pause time in the frame will be immediately loaded into the pause time counter.

### Receive operation multiframe handling

Since the status is available immediately following the data, the RXFIFO is capable of storing any number of frames into it, as long as it is not full.

### Receive status word

At the end of the Ethernet frame reception, the EMAC will send the receive status to the application (DMA). The detailed information of the receive status is given in the RDES0.

### EMAC loopback mode

The EMAC supports loopback of transmitted frames onto its receiver. The loopback mode is very useful to debug the Ethernet communication. This feature is enabled by setting the LM bit in the EMAC\_MACCTRL register.

Note that the loopback mode is applicable only to the MII interface.

### EMAC frame counter

The MAC management counters (MMC) contain a set of registers for gathering statistics on the received and transmitted frames. These include the EMAC\_MMCTR, EMAC\_MMCR1, EMAC\_MMCRIM, EMAC\_MMCTI and EMAC\_MMCTIM registers.

If a frame transmission is aborted due to any of the following errors, this frame will not be counted:

1. No carrier/Loss of carrier
2. Jabber timeout
3. Late collision
4. Excessive collision

5. Excessive deferral

6. Frame overflow

If a frame reception is aborted due to any of the following errors, this frame will not be counted:

1. CRC error

2. Runt frame (shorter than 64 bytes)

3. Alignment error

4. Length error (length field value does not match the received frame length)

5. Out of range (frame length beyond the maximum size, untagged frame maximum size=1518 bytes, tagged frame maximum size=1522 bytes)

6. MII\_RXER input error

### 26.2.3 Ethernet frame transmission and reception using DMA

The transmission and reception of the Ethernet frames are scheduled through DMA.

For transmission, the DMA reads out the Ethernet frames from the user system buffer (such as SRAM) via the AHB master interface and forwards them to the TXFIFO. The EMAC core then transfers the data frames in the TXFIFO to the MII/RMII interface.

For reception, the EMAC core sends the received Ethernet frames from the MII/RMII interface to the RXFIFO so that the DMA controller reads out the Ethernet frames from the RXFIFO and transfers them to the user data buffer (SRAM) via the AHB master interface.

DMA control and status register and descriptor table are used to manage the whole transmission and reception process, which has its respective descriptor list. The descriptor list is usually stored in the system buffer area (SRAM). When the transmission and reception is enabled, the DMA polls the descriptor table through the transmit and receive poll register to start the transmission and reception process. The base address the descriptor list for transmission and reception is stored into the transmit descriptor list register and receive descriptor list register.

There are two descriptor structures: ring structure and chain structure. In a ring structure, each descriptor may point to two buffers. In a chain structure (TDES0[20]=1 is configured for transmission, but RDES1[14]=1 for reception), each descriptor points to the only one buffer. The contents of the TDES3 and RDES3 for the current frames refer to the next descriptor address for transmission and reception.

Figure 26-10 Descriptor for ring and chain structure



### DMA AHB host burst access

The DMA executes a fixed-length burst access on the AHB master interface if the FB bit is set in the EMAC\_DMABM register. The maximum burst length is defined by the PBL field (bit [13: 8] in the EMAC\_DMABM register). The receive and transmit descriptors are always accessed in the maximum possible burst size (limited by PBL) for the 16 bytes to read.

The DMA provides the start address and the number of transfers to the AHB master interface before starting one transfer.

Note that one of the following conditions must be respected for transmission:

1. TXFIFO space is greater than the programmed burst size
2. The number of bytes before the end of a frame is less than the burst size and the TXFIFO can accommodate these bytes

One of the following conditions must be respected for reception:

1. The data available in the RXFIFO is greater than the programmed burst size
2. The number of bytes before the end of a frame is less than the burst size and the end of the frame is detected in the RXFIFO

### AHB host data alignment

The DMA always initiates transfers with address aligned to the bus width. But the start address of the buffers can be aligned to any of the four bytes.

- Example of buffer read: If the transmit buffer address is 0x2000 0AA3, and 15 bytes are to be transferred, then the DMA will read five words (32 bits) from the address 0x2000 0AA0, but when transferring data to the TXFIFO, the first three bytes and the last two bytes will be ignored. The DMA always ensures that it transfers a 32-bit data to the TXFIFO, unless it is the end of the frame.
- Example of buffer write: If the receive buffer address is 0x2000 0BB2 and 16 bytes are to be transferred, the DMA will read five 32-bit data from the address 0x2000 0BB0. But the first two bytes and the last two bytes are dummy data.

### Buffer size calculation

For transmission, software needs to calculate the buffer size. The TXDMA transfers the exact number of bytes programmed by buffer size field in the TDES1 to the EMAC core. If the FS bit is set in the TDES0, the DMA marks the first transfer from the buffer as the start of frame. If the LS bit is set in the TDES0, the DMA marks the last transfer from the buffer as the end of frame.

During a frame reception, if the receive buffer address is word-aligned, the valid length of the buffer refers to the value programmed in the RDES1 if the receive buffer address is not word-aligned, the valid length of the buffer is less than the value configured in the RDES1. The valid length value of the buffer is the value indicated by the RDES1 minus the lower two bit value of the buffer address. For example, if the total buffer size is 1024 bytes and the buffer address is 0x2000 0001, the lower 2-bit value of the address is 0x01, then the valid buffer size is 1023 bytes.

The FS bit is set by the DMA controller when an SOF is received. The LS is set when an EOF is received. If the receive buffer length field is big enough to accommodate a full frame, then both the FS and LS bits will be set in the same descriptor. The actual length of the received frame is indicated by the FL bit in the RDES0.

### DMA arbiter

Two types of arbitrations are used for the arbitration between transmit and receive controller: round-robin, and fixed-priority. When round-robin is selected (DA bit is set to 0 in the EMAC\_DMABM register), the arbiter allocates the databus according to the ratio set by the PR bit in the EMAC\_DMABM register, when both transmit and RXDMA request access to the AHB bus simultaneously. When the DA bit is set to 1, the RXDAM always has priority over the TXDMA for data access.

### Error response to DMA

If an error response is received during DMA transfer, then the DMA stops all operations and updates the error bit and the fatal bus error bit in the EMAC\_DMASTS register. The DMA can resume operation after software or hardware resets the Ethernet peripherals and re-initiates the DMA.

## DMA initialization

1. Configure AT32F437xx bus access parameters in the EMAC\_DMABM register.
2. Mask unnecessary interrupt sources in the EMAC\_DMAIE register.
3. The application generates the transmit and receive descriptor lists. Then it writes the start addresses of the descriptor lists to both the EMAC\_DMARDLADDR and EMAC\_DMATDLADDR registers.
4. Configure address filtering registers.
5. Configure the EMAC\_MACCTRL register to enable the transmit and receive operating modes  
Program the PS and DM bits according to the auto-negotiation result
6. Set the bit 13 and bit 1 in the EMAC\_DMAOPM register to enable transmission and reception.
7. The transmit and receive controllers begin reading descriptors from the corresponding descriptor lists to process receive and transmit operations.

## TxDMA operation: non-OSF mode

The TxDMA proceeds as follows, in default mode:

1. The application sets up the Ethernet frame data buffer and the transmit descriptor (TDES0-TDES3), and sets the OWN bit (TDES0[31])
2. Once the SSTC is set (EMAC\_DMAOPM bit [13]), the DMA enables transmission.
3. The DMA polls the transmit descriptor to get a frame to be transmitted. If the DMA detects a descriptor that is being owned by the CPU or if an error occurs, transmission is suspended and suspend state is entered, and both the transmit buffer unavailable (EMAC\_DMASTS bit 2) and normal interrupt summary bit (EMAC\_DMASTS bit 16) are set. The transmit controller jumps to Step 8.
4. DMA fetches the data from the AT32F437xx memory based on the transmit descriptor indication and transfers the data to the TXFIFO.
5. If the Ethernet frame is stored in multiple descriptors with different descriptor, the DMA will close the intermediate descriptor and fetch the next descriptor. Steps 3, 4 and 5 are repeated until the end of frame data is transferred.
6. When the frame transmission is complete, if IEEE1588 time stamping was enabled for the frame (as indicated in the transmit status), the time stamp value is written to the transmit descriptor (TDES2 and TDES3) that contains the end-of-frame buffer while the transmit status information is sent to the TDES0. Then the OWN bit is cleared, and the current descriptor is disabled. If time stamping was not enabled for the frame, the DMA only updates the status information to the TDES0 without recording the time stamping
7. When the frame transmission is complete, if the Interrupt on Completion (TDES0[30]) is set, then the transmit interrupt bit (EMAC\_DMASTS bit [0]) will be set. The DMA then returns to Step 3 and is ready for the next transmission.
8. In the suspend state, the DAM tries to re-fetch the descriptor (back to Step 3) when it receives a transmit poll request and the overflow interrupt flag bit is cleared.

## TxDMA operation: OSF mode

In this mode, the OSF bit is set (EMAC\_DMAOPM bit 2=1). When the current data frame transmission is complete, the DMA immediately polls the transmit descriptor for the second frame without the need of waiting for the status information is written.

1. The DMA operates according to steps 1-6 of the TxDMA.
2. The DMA fetches the next descriptor without waiting for the status information update of the last description for the previous frame.
3. If the DMA owns the descriptor, then it will decode the transmit buffer address. If the DMA does not own the descriptor, then it will enter into suspend state and jump to Step 7.
4. The DMA fetches the transmit frame data from the AT32F437xx memory and transfer the frame until the end of frame is transferred. If the frame is split among multiple buffers, the DMA will close the intermediate descriptors.
5. The DMA waits for the transmit status and time stamp of the previous frame. After the status information is available, the DMA writes the time stamp to TDES2 and TDES3 if such time stamp

is captured. The DMA then clears the OWN bit and closes the descriptor. If the time stamping was not enabled for the frame, the DMA will not alter the contents of TDES2 and TDES3.

6. If enabled, the transmit interrupt bit is set. The DMA fetches the next descriptor when the status information is normal, and jumps to Step 3. If the previous transmit status shows an underflow error, the DMA enters into suspend state and jumps to Step 7.
7. In suspend state, when the DMA receives a pending status information and time stamp, if the time stamping is enabled it will write the time stamp to TDES2 and TDES3, and writes the status to TDES0. It then sets relevant interrupt flag bits and returns to suspend state.
8. The DMA can exit suspend state and enter run state only after receiving a transmit poll request (EMAC\_DMACTD register).

### Transmit frame processing

Ethernet frames stored in the transmit buffer must contain destination address, source address, correct type/length field and valid data. As for whether to include CRC value, it depends on the transmit descriptor. If the transmit descriptor requires the EMAC core to disable CRC or pad insertion, the buffer must contain the CRC.

A frame can be stored in multiple buffers that are linked in chain structure. When the transmission starts, the TDES0 bit 28 must be set in the first descriptor, and then the data are transferred from the memory to the TXFIFO. If the TDES0 bit 29 is set, it indicates the last buffer of the frame. After the last buffer of the data has been completed, the DMA writes back the final status information to the TDES0. If the transmit complete interrupt bit (TDES0[30]) is set, the transmit interrupt bit (EMAC\_DMASTS bit 0) is set, the next descriptor is fetched, and the above steps are repeated. Actual frame transmission depends on whether the store-and-forward mode or threshold mode is selected. The descriptor is disabled (TDES0[31] is cleared) when the DMA finishes frame transmission.

### Transmit polling suspend

Transmit polling can be suspended by one of the following conditions:

The DMA detects a descriptor owned by the CPU (TDES0[31]=0), and the DMA enters suspend state. A frame transmission is aborted when an underflow is detected. The abnormal interrupt summary bit (EMAC\_DMASTS bit 15) and transmit data underflow bit (EMAC\_DMASTS bit 5) are set, and the appropriate error bit is set in the TDES0.

### TXDMA descriptors

The descriptor structure consists of four 32-bit words. The bit definitions of TDES0, TDES1, TDES2 and TDES3 are as shown below:

Figure 26-11 Transmit descriptors



TDES0: Transmit descriptor word0

The software must configure the control bits [30: 26]+ [23: 20] and the OWN bit during descriptor initialization. When the DMA updates or writes the descriptor, it clears all the control bits and OWN bit, and report only the status bits.

| Bit        | Name          | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |               |      | Own bit<br>0: The descriptor is owned by the CPU<br>1: The descriptor is owned by the DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 31     | OWN           | rw   | This bit is cleared by the DMA when the DMA completes the frame transmission or when all the data in the buffer are read completely. The own bit of the frame's first descriptor can be set only after subsequent descriptors for the same frame have been set.                                                                                                                                                                                                                                                                                                                            |
| Bit 30     | IC            | rw   | Interrupt on completion<br>When set, this bit sets the transmit interrupt bit (EMAC_DMASTS bit [0]) after the present frame has been transmitted. This bit is valid only when the LS bit is set.                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 29     | LS            | rw   | Last segment<br>When set, this bit indicates that the buffer contains the last segment of the frame. When this bit is set, neither TBS1 nor TBS2 can be cleared in the TDES1.                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 28     | FS            | rw   | First segment<br>When set, this bit indicates that the buffer contains the first segment of the frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 27     | DC            | rw   | Disable CRC<br>When set, the MAC does not append a CRC field to the end of the transmitted frame. This bit is valid only when the FS bit is set (TDES0[28]=1).                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 26     | DP            | rw   | Disable pad<br>0: The MAC automatically adds padding to a frame shorter than 64 bytes, and the CRC field is added despite the state of the DC (TDES0[27]). This bit is valid only when the FS bit is set (TDES0[28]).<br>1: The MAC does not automatically add padding to a frame shorter than 64 bytes.                                                                                                                                                                                                                                                                                   |
| Bit 25     | TTSE          | rw   | Transmit time stamp enable<br>When this bit is set, the IEEE1588 hardware time stamp is activated for the transmit frame described by the descriptor. This bit is valid only when both the TSE (EMAC_PTPTSCTRL[0]) and FS bits (TDES0[28]) are set.                                                                                                                                                                                                                                                                                                                                        |
| Bit 24     | Reserved resd |      | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 23: 22 | CIC           | rw   | Checksum insertion control<br>These two bits control the checksum calculation and insertion, as shown below:<br>00: Checksum insertion disabled<br>01: Only IP header checksum calculation and insertion are enabled<br>10: IP header checksum and data checksum calculation and insertion are enabled, but pseudo-header checksum is not calculated.<br>11: IP header checksum and data checksum calculation and insertion are enabled, and pseudo-header checksum is calculated.                                                                                                         |
| Bit 21     | TER           | rw   | Transmit end of ring<br>When set, it indicates that the descriptor list reached its final descriptor. The DMA returns to the start address of the list, creating a descriptor ring.                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 20     | TCH           | rw   | Second address chained<br>When set, it indicates that the TBS2 bit in the TDES1 refers to the second descriptor address rather than the second buffer address. TDES0[21] takes precedence over TDES0[20]. This bit is valid only when the TDES0[28] is set.                                                                                                                                                                                                                                                                                                                                |
| Bit 19: 18 | Reserved resd |      | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 17     | TTSS          | rw   | Transmit time stamp status<br>This bit is used as a status bit to indicate that a time stamp is captured for the described transmit frame. When this bit is set, it indicates the time stamp of the transmitted frame described by the descriptor has been captured, which are stored in the TDES2 and TDES3. This bit is valid only when the LS bit is set (TDES0[29]).                                                                                                                                                                                                                   |
| Bit 16     | IHE           | rw   | IP header error<br>When set, it indicates that the MAC transmitter detected an error in the IP data packet header. For IPv4 frames, the MAC checks whether the length field in the IPv4 datagram does match the number of received IPv4 data. If there is a mismatch, an error is given. For IPv6 frames, an error is reported when the header length is not 40 bytes. Furthermore, the length/type field value for an IPv4 or IPv6 frame must match the IP header version. For IPv4 frame, an error is reported and this bit is set if the header length field value is shorter than 0x5. |
| Bit 15     | ES            | rw   | Error summary<br>This bit indicates the logical OR of the following bits:<br>TDES0[14]: Jabber timeout<br>TDES0[13]: Frame flush<br>TDES0[11]: Loss of carrier<br>TDES0[10]: No carrier                                                                                                                                                                                                                                                                                                                                                                                                    |

|          |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |     |    | TDES0[9]: Late collision<br>TDES0[8]: Excessive collision<br>TDES0[2]: Excessive deferral<br>TDES0[1]: Underflow error<br>TDES0[16]: IP header error<br>TDES0[12]: IP data error                                                                                                                                                                                                                                                                  |
| Bit 14   | JT  | rw | Jabber timeout<br>When set, this bit indicates that the MAC transmitter has experienced a jabber timeout. This bit is set only when the JAD bit is not set in the EMAC_MACCTRL register.                                                                                                                                                                                                                                                          |
| Bit 13   | FF  | rw | Frame flushed<br>When set, this bit indicates that the DMA or MTL flushed the frame in the FIFO due to a flush command given by the CPU.                                                                                                                                                                                                                                                                                                          |
| Bit 12   | IPE | rw | IP payload error<br>When set, this bit indicates that the MAC transmitter detected an error in the TCP, UDP or ICMP. The transmitter compares the length field received in the IPv4 or IPv6 with the actual number of TCP, UDP or ICMP bytes. This bit is set as an error warning if there is a match.                                                                                                                                            |
| Bit 11   | LOC | rw | Loss of carrier<br>When set, this bit indicates that a loss of carrier occurred during a frame transmission (The MII_CRS signal is active for one or more transmit clock periods). This bit is valid only for the frame transmitted without collision while the MC operates in half-duplex mode.                                                                                                                                                  |
| Bit 10   | NC  | rw | No carrier<br>When set, this bit indicates that the carrier sense signal from the PHY was not set during a frame transmission.                                                                                                                                                                                                                                                                                                                    |
| Bit 9    | LC  | rw | Late collision<br>When set, this bit indicates that frame transmission was aborted due to a collision detected after the collision window (64 byte times, including preamble, in MII mode). This bit is invalid if the underflow error bit is set.                                                                                                                                                                                                |
| Bit 8    | EC  | rw | Excessive collision<br>When set, this bit indicates that the frame transmission was aborted after 16 consecutive collisions while attempting to transmit the current frame. If the RD bit (Retry disabled) bit in the EMAC_MACCTRL register is set, then this bit is set after the first collision, and the transmission of the frame is aborted.                                                                                                 |
| Bit 7    | VF  | rw | VLAN frame<br>When set, this bit indicates that the transmitted frame is a VLAN-type frame.                                                                                                                                                                                                                                                                                                                                                       |
| Bit 6: 3 | CC  | rw | Collision count<br>This field indicates the number of collisions experienced before the frame was transmitted. This bit is invalid when the EC bit is set (TDES0[8]). It is valid only in half-duplex mode.                                                                                                                                                                                                                                       |
| Bit 2    | ED  | rw | Excessive deferral<br>When set, this bit indicates that the transmission ended because of excessive deferral of over 24288 bit times when the DC bit is set in the EMAC_MACCTRL register.                                                                                                                                                                                                                                                         |
| Bit 1    | UF  | rw | Underflow error<br>When set, this bit indicates that the MAC stopped the frame transmission because data arrived late from the system memory to the MAC. Underflow error indicates that the DMA encountered an empty transmit buffer while transmitting the frame. The transmission process enters the suspend state and sets both the bit 5 (TU) in the EMAC_DMASTS register and the transmit interrupt bit (bit 0 in the EMAC_DMASTS register). |
| Bit 0    | DB  | rw | Deferred bit<br>When set, this bit indicates that the MAC defers frame transmission because of the presence of the carrier. This bit is valid only in half-duplex mode.                                                                                                                                                                                                                                                                           |

**TDES1: Transmit descriptor word1**

| Bit        | Name     | Type | Description                                                                                                                                                             |
|------------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 29 | Reserved | resd | Kept at its default value.                                                                                                                                              |
| Bit 28: 16 | TBS2     | rw   | Transmit buffer 2 size<br>This field indicates the second data buffer size in bytes. When the TDES0[20] bit is set, this field indicates the second descriptor address. |
| Bit 15: 13 | Reserved | resd | Kept at its default value.                                                                                                                                              |

|           |      |    |                                                                                                                                                                                                          |
|-----------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 12: 0 | TBS1 | rw | Transmit buffer 1 size<br>This field indicates the first data buffer size in bytes. If the field is 0, the DMA ignores this buffer and uses buffer 2 or the next buffer, depending on the TDES0[20] bit. |
|-----------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**TDES2: Transmit descriptor word2**

TDES2 contains the address pointer to the first buffer of the descriptor.

| Bit       | Name           | Type | Description                                                                                                                                                                                                                                                                                                       |
|-----------|----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TBAP1/T<br>TSL | rw   | Transmit buffer 1 address pointer / Transmit frame time stamp low<br>This field has two functions:<br>1: The application indicates to the DMA the location of the Ethernet data in system memory.<br>2: After all data are transferred, the DMA can use these bits to store the time stamp of the transmit frame. |
|           | TBAP1          |      | When the current descriptor is owned by the DMA, these bits indicate the physical address of the buffer 1.                                                                                                                                                                                                        |
|           | TTSL           |      | Before it releases the descriptor to the CPU, the DMA writes the 32 least significant bits of the time stamp capture for the corresponding transmit frame to this field. This field has the time stamp only when the TTSE bit in the TDES0 and the LS bit for the frame are set.                                  |

**TDES3: Transmit descriptor word3**

TDES3 contains the address pointer to the second buffer of the descriptor.

| Bit       | Name           | Type | Description                                                                                                                                                                                                                                                                                                                                                          |
|-----------|----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TBAP2/T<br>TSH | rw   | Transmit buffer 2 address pointer (Next descriptor address) / Transmit frame time stamp high<br>This field has two functions:<br>1: The application indicates to the DMA the location of the Ethernet data in system memory.<br>2: After all data are transferred, the DMA can use these bits to store the 32 most significant bits of the time stamp for the frame. |
|           | TBAP2          |      | When the current descriptor is owned by the DMA, these bits indicate the physical address of buffer2 if a descriptor ring structure is used. If a descriptor chain structure is used, these bits indicate the physical address of the next descriptor.                                                                                                               |
|           | TTSH           |      | Transmit frame time stamp high<br>The DMA updates these bits with the 32 most significant bits of the time stamp captured for the corresponding frame. This field has the time stamp only when the TTSE bit in the TDES0 and the LS bit for the frame are set.                                                                                                       |

**TXDMA enhanced descriptor**

Under the two conditions below, enhanced TXDMA descriptors must be used.

1. Time stamping is activated (by setting TE to 1 in the EMAC\_PTPTSCTRL register)
2. IPV4 checksum is activated (by setting IPC to 1 in the EMAC\_MACCTRL register)

Enhanced TXDMA descriptor feature is enabled by setting EDE to 1 in the EMAC\_DMABM register. Enhanced TX descriptors include TDES0,TDES1,TDES2,TDES3,TDES4,TDES5,TDES6 and TDES7, 8x 32-bit words in total.

Within them, TDES0~3 have the same functions as regular TX descriptors; TDES4~5 are unused; TDES6~7 are to store 64-bit time stamp.

**TDES6: Transmit descriptor word 6**

TDES6 contains the 32 least significant bits of the time stamp captured

| Bit       | Name | Type | Description                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TTSL | rw   | The DMA updates this field with the 32 least significant bits of the time stamp captured for the corresponding transmit frame to this field before releasing descriptors to CPU. The DMA updates this field only after the time stamp is enabled (setting bit 25 TTSE to 1 in the TDES0) and LS bit is to 1 (which means the completion of the current frame transmission). |

TDES7: Transmit descriptor word 7

TDES7 contains the 32 most significant bits of the time stamp captured.

| Bit | Name | Type | Description                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |      | <p>Transmit frame time stamp high</p> <p>The DMA updates this field with the 32 most significant bits of the time stamp capture for the corresponding transmit frame. The DMA updates this field only after the time stamp is enabled (setting bit 25 TTSE to 1 in the TDES0) and LS bit is to 1 (which means the completion of the current frame transmission).</p> |

### RXDMA configuration

3. The application sets up receive descriptors (RDES0~RDES3), sets the OWN bit and then releases the descriptors to the DMA.
4. When the SSR bit (EMAC\_DMAOPM[1]) is set, the DMA enters run state and attempts to acquire receive descriptors. If the fetched descriptor is not free (owned by the CPU), the DMA enters suspend state and jumps to Step 9.
5. The DMA decodes the receive buffer address from the acquired receive descriptors.
6. The DMA writes the frame data in the RXFIFO to the receive buffer.
7. When the buffer is full or the frame transfer ends, the receive controller will fetch the next descriptor from the descriptor queue.
8. If the current frame transfer is complete, the DMA jumps to Step 7. If the OWN bit of the next receive descriptor is cleared while the current frame is not complete (EOF is not received), when the frame flushing function is enabled, the DMA sets the descriptor error bit in the RDES0, closes the current descriptor (OWN=0) and sets the LS bit in the RDES1, and then jumps to Step 8 (Note that the LS bit in the RDES1 will not be set if the frame flushing feature is disabled). When the OWN bit of the next descriptor is set while the current frame transfer is not complete, the DMA then closes the current descriptor, marks it as intermediate and jumps to Step 4.
9. If IEEE1588 time stamp is enabled, the DMA writes the time stamp to the current descriptor's RDES2 and RDES3 while it writes the status word to the RDES0, with the OWN bit cleared and the LS bit set.
10. The receive controller checks the latest receive descriptors, if the DMA owns the descriptor, the receive controller will return to Step 4. If the CPU owns the descriptor, the RXDMA will enter suspend state and set the receive buffer unavailable bit, and the controller will flush the received frames if the receive frame flushing feature is enabled.
11. The DMA exits the suspend state when a receive poll demand is received or the start of the next frame is available in the receive FIFO. The receive controller fetches the next descriptor and jumps to Step 2.

### Receive descriptor acquisition

The RXDMA always attempts to acquire another descriptor. Receive descriptor is attempted if any of the following conditions is satisfied:

- The DMA enters the run state ( SSR=1 in the EMAC\_DMAOPM).
- The buffer of the current descriptor is full before a full or part of the frame being transferred.
- The controller has completed the current frame reception, but the current receive descriptor has not yet been closed.
- A new frame is received but the receive process is suspended because the descriptor is owned by the CPU.
- A receive poll demand received.

### Receive frame processing

The MII/RMI interface receives the receive frame and writes it to the RXFIFO. When a programmed threshold is reached, the RXDMA begins transferring the frame data to the receive buffer pointed to by the current descriptor. The DMA sets the LS bit in the RDES0 to indicate that this is the first segment of the frame in the buffer. The descriptors are released by clearing the OWN bit when the data buffer fills

up or at the end of the frame reception. If the current descriptor buffer is enough to accommodate the complete frame, the current description RDES0 LS and FS bits are set.

The DMA fetches the next descriptor, sets the LS bit in the previous descriptor, writes the receive status word to the previous descriptor and then closes the previous descriptor. Then the DMA sets the receive interrupt bit (EMAC\_DMASTS[6]). The same process repeats unless the DMA finds a descriptor as being owned by the CPU. If this occurs, the receive process sets the receive buffer unavailable bit (EMAC\_DMASTS[7]) and then enters the suspend state. Before the suspend state is being entered, the current pointer value in the descriptor list is retained, which is used as the start address of a descriptor after exiting the suspend state.

### Receive process suspended

If a new receive frame arrives in the RXFIFO while the RXDMA is in suspend state, the DMA re-fetches the current descriptor in the AT32F437xx memory. If the OWN bit of the fetched descriptor is set, the receive process re-enters the run state. If the OWN bit is cleared, the DMA discards the current frame at the top of the RXFIFO and increments the missed frame counter. If more than one frame is stored in the RXFIFO, the process repeats. The flushing or discarding of the frame at the top of the receive FIFO can be avoided by setting the bit 24 (DFRF bit) in the EMAC\_DMAOPM register. In this case, the receive process sets the receive buffer unavailable bit and returns to the suspend state.

### RXDMA descriptors

The descriptor structure consists of four 32-bit words: RDES0, RDES1, RDES2 and RDES3.

Figure 26-12 RXDMA descriptor structure



RDES0: Receive descriptor word0

RDES0 contains the receive frame state, the frame length and the descriptor ownership information.

| Bit        | Name | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | OWN  | rw   | Own bit<br>0: The descriptor is owned by the CPU<br>1: The descriptor is owned by the DMA<br>This bit is cleared by the DMA when the DMA completes the frame transmission or when the buffers associated with this descriptor are full. The descriptor is released to the CPU.                                                                                                                                                                                                  |
| Bit 30     | AFM  | rw   | Destination address filter fail<br>When set, this bit indicates that a frame failed the DA filter in the MAC core.                                                                                                                                                                                                                                                                                                                                                              |
| Bit 29: 16 | FL   | rw   | Frame length<br>These bits indicate the byte length of the received frame that was transferred to the system memory by the DMA. This field is valid only when the LS bit (RDES0[8]) is set and descriptor error bit is cleared (RDES0[14]). If the LS bit is cleared, this field indicates the accumulated number of bytes that have been transferred to the system memory. Whether the frame length includes CRC depends on the bit 7 and bit 25 in the EMAC_MACCTRL register. |
| Bit 15     | ES   | rw   | Error summary<br>This bit indicates the logical OR of the following bits:<br>RDES0[1]: CRC error<br>RDES0[3]: Receive error<br>RDES0[4]: Watchdog timeout<br>RDES0[6]: Late collision<br>RDES0[7]: Giant frame or IP checksum error<br>RDES0[11]: Overflow error<br>RDES0[14]: Descriptor error                                                                                                                                                                                 |
| Bit 14     | DE   | rw   | Descriptor error<br>When set, this bit indicates a frame truncation caused by a frame that does not fit with the current descriptor buffers, and that the DMA does not own the next descriptor. This bit is valid only when the LS bit (RDES0[8]) is set.                                                                                                                                                                                                                       |
| Bit 13     | SAF  | rw   | Source address filter fail<br>When set, this bit indicates that the received frame failed the SA filter in the MAC core.                                                                                                                                                                                                                                                                                                                                                        |
| Bit 12     | LE   | rw   | Length error<br>When set, this bit indicates that the actual length of the received frame does not match the value in the Ethernet length/type field. This bit is valid only when the RDES0[5] bit is cleared. It is invalid when a CRC error occurs.                                                                                                                                                                                                                           |
| Bit 11     | OE   | rw   | Overflow error<br>When set, this bit indicates that the received frame was damaged due to receive FIFO overflow.                                                                                                                                                                                                                                                                                                                                                                |
| Bit 10     | VLAN | rw   | VLAN tag<br>When set, this bit indicates that the frame pointed to by the current descriptor is                                                                                                                                                                                                                                                                                                                                                                                 |

|       |       |    |                                                                                                                                                                                                                                                                                                                                          |
|-------|-------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |    | marked as a VLAN frame by the MAC.                                                                                                                                                                                                                                                                                                       |
| Bit 9 | FS    | rw | First descriptor<br>When set, this bit indicates that this descriptor contains the first buffer of the frame. If the size of the first buffer is 0, the second buffer contains the beginning of the frame. If the size of the second buffer is also 0, the buffer of the next descriptor contains the beginning of the frame.            |
| Bit 8 | LS    | rw | Last descriptor<br>When set, this bit indicates that the buffers pointed to by this descriptor are the last buffers of the frame.                                                                                                                                                                                                        |
| Bit 7 | IPHCE | rw | IPv header checksum error<br>When set, this bit indicates an error in the IPv4 or IPv6 header. This error can be due to mismatched Ethernet type field and IP version field, IPv4 header checksum error or an Ethernet frame lacking the desired number of IP header bytes.                                                              |
| Bit 6 | LC    | rw | Late collision<br>When set, this bit indicates that a late collision has occurred while receiving the frame in half-duplex mode.                                                                                                                                                                                                         |
| Bit 5 | FT    | rw | Frame type<br>When set, this bit indicates that the received frame is an Ethernet frame (the LT field is greater than or equal to 1536). When this bit is cleared, it indicates that the received frame is an IEEE802.3 frame. This bit is invalid when the received frame is a runt frame shorter than 14 bytes.                        |
| Bit 4 | RWT   | rw | Receive watchdog timeout<br>When set, this bit indicates the receive watchdog timeout has occurred while receiving the current frame. The current frame is truncated after the watchdog timeout.                                                                                                                                         |
| Bit 3 | RE    | rw | Receive error<br>When set, this bit indicates that the RX_ER signal is valid while the RX_DV is valid during frame reception.                                                                                                                                                                                                            |
| Bit 2 | DE    | rw | Dribble bit error<br>When set, this bit indicates that the received frame is not an integer multiple of bytes (odd nibbles) This bit is valid only in MII mode.                                                                                                                                                                          |
| Bit 1 | CE    | rw | CRC error<br>When set, this bit indicates a CRC error occurred on the received frame. This bit is valid only when the LS bit is set.                                                                                                                                                                                                     |
| Bit 0 | PCE   | rw | Payload checksum error<br>When set, this bit indicates that the TCP, UDP or ICMP checksum calculated by the MAC core does not match the received TCP, UDP or ICMP checksum field. This bit is also set when the received payload size does not match the length field value of the IPv4 or IPv6 datagram in the received Ethernet frame. |

Table 26-7 shows the definitions of bit 5, 7 and 0.

Table 26-7 Receive descriptor 0

| Bit 5:<br>Frame type | Bit 7:<br>Checksum<br>error | Bit 0:<br>Payload<br>checksum<br>error | Frame status                                                                                                                |
|----------------------|-----------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 0                    | 0                           | 0                                      | IEEE802.3 type frame (length field value is less than 0x0600)                                                               |
| 1                    | 0                           | 0                                      | IPv4/IPv6 type frame, no checksum error detected                                                                            |
| 1                    | 0                           | 1                                      | IPv4/IPv6 type frame with payload checksum error detected (PCE bit)                                                         |
| 1                    | 1                           | 0                                      | IPv4/IPv6 type frame with an IP header checksum error detected (IPC CE bit)                                                 |
| 1                    | 1                           | 1                                      | IPv4/IPv6 type frame with both IP header and payload checksum errors detected                                               |
| 0                    | 0                           | 1                                      | IPv4/IPv6 type frame with no IP header checksum error detected and the payload check bypassed due to an unsupported payload |
| 0                    | 1                           | 1                                      | A type frame is neither IPv4 nor IPv6 (the checksum offload bypasses checksum inspection)                                   |
| 0                    | 1                           | 0                                      | Reserved                                                                                                                    |

## RDES1: Receive descriptor 1

| Bit        | Name          | Type | Description                                                                                                                                                                                                                                                                                                |
|------------|---------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | DIC           | rw   | Disable interrupt on completion<br>When set, this bit prevents setting the Ethernet DMA status register's RECV bit (EMAC_DMSTS) for the received frame pointed to by this descriptor. As a result, this disables the interrupt triggered by the RECV bit. This bit is valid only when the RDES0[8] is set. |
| Bit 30: 29 | Reserved resd |      | Kept at its default value.                                                                                                                                                                                                                                                                                 |
| Bit 28: 16 | RBS2          | rw   | Receive buffer 2 size<br>This field indicate the receive buffer 2 size, in bytes. It is invalid if the RDES1[14] bit is set.                                                                                                                                                                               |
| Bit 15     | RER           | rw   | Receive end of ring<br>When set, this bit indicates that the current descriptor is the last one in the descriptor list. The DMA returns to the base address to fetch the next descriptor, creating a descriptor ring.                                                                                      |
| Bit 14     | RCH           | rw   | Second address chained<br>When set, this bit indicates that the second address in the descriptor is the next descriptor address rather than the second buffer address. When this bit is set, RBS2(TDES1[28: 16]) value can be ignored. RDES0[15] takes precedence over RDES0[14].                          |
| Bit 13     | Reserved resd |      | Kept at its default value.                                                                                                                                                                                                                                                                                 |
| Bit 12: 0  | RBS1          | rw   | Receive buffer 1 size<br>This field indicates the receive buffer 1 size, in bytes. If this field is 0, the DMA ignores this buffer and uses buffer 2 or next descriptor depending on the RDES[14] value.                                                                                                   |

## RDES2: Receive descriptor word2

RDES2 contains the address pointer to the first data buffer in the descriptor.

| Bit       | Name           | Type | Description                                                                                                                                                                                                                                                                 |
|-----------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | RBAP1/R<br>TSL | rw   | Receive buffer 1 address pointer /Receive frame time stamp low<br>These bits have two functions. The application uses them to indicate to the DMA where to store the data in memory. After completing data reception, the DMA may use these bits to store frame time stamp. |
| Bit 31: 0 | RBAP1          | rw   | When this descriptor is owned by the DMA, these bits indicate the physical address of buffer 1.                                                                                                                                                                             |
|           | RTSL           |      | Before it releases the descriptor, the DMA updates this field with the 32 least significant bits of the time stamp. The time stamp is written by the DMA only when the time stamp and LS bit are set (indicating that the last segment of the frame is stored in memory).   |

## RDES3: Receive descriptor word3

RDES3 contains the address pointer to the second data buffer in the descriptor.

| Bit       | Name           | Type | Description                                                                                                                                                                                                                                                                                                         |
|-----------|----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | RBAP2/R<br>TSH | rw   | Receive buffer 2 address pointer (next descriptor address)/Receive frame time stamp high<br>Bit [31:0]<br>These bits have two functions. The application uses them to indicate to the DMA where to store the data in memory. After completing data reception, the DMA may use these bits to store frame time stamp. |
| Bit 31: 0 | RBAP2          | rw   | When this descriptor is owned by the DMA, these bits indicate the physical address of buffer 2 when a descriptor ring structure is used. If the second address chained bit (RDES0[14]) is set, these bits point to the physical address of the next descriptor while the next descriptor is present.                |
|           | RTSH           |      | Before it releases the descriptor, the DMA updates this field with the 32 most significant bits of the time stamp. The time stamp is written by the DMA only when the time stamp and LS bit are set (indicating that the last segment of the frame is stored in memory).                                            |

**RXDMA enhanced descriptor**

Under the two conditions below, enhanced RXDMA descriptors must be used.

1. Time stamping is activated (by setting TE to 1 in the EMAC\_PTPTSCTRL register)
2. IPV4 checksum is activated (by setting IPC to 1 in the EMAC\_MACCTRL register)

Enhanced RXDMA descriptor feature is enabled by setting EDE to 1 in the EMAC\_DMABM register. Enhanced RX descriptors include RDES0,RDES1,RDES2,RDES3,RDES4,RDES5,RDES6 and RDES7, 8x 32-bit words in total.

Within them, RDES0~3 have the same definitions as for normal RX descriptors; RDES4 contains extended status; RDES6~7 hold 64-bit time stamp.

#### RDES4: Receive descriptor word 4

| Bit        | Name          | Type | Description                                                                                                                                                                                                                                                                                                                                                       |
|------------|---------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 14 | Reserved resd |      | Kept at default value                                                                                                                                                                                                                                                                                                                                             |
| Bit 13     | PV            | ro   | PTP version<br>0: IEEE 1588 version 1<br>1: IEEE 1588 version 2                                                                                                                                                                                                                                                                                                   |
| Bit 12     | PFT           | ro   | PTP frame type<br>When this bit is set to 1, it indicates that the PTP message is sent directly over Ethernet. When this bit is cleared and the message type is non-zero, it indicates that the PTP message is sent over UDP-IPv4 or UDP-IPv6. The information on IPv4 or IPv6 can be obtained from bit 6 and bit 7.                                              |
| Bit 11: 8  | PMT           | ro   | PTP message type<br>0000: No PTP message received<br>0001: SYNC<br>0010: Follow_Up<br>0011: Delay_Req<br>0100: Delay_Resp<br>0101: Pdelay_Req/Announce<br>0110: Pdelay_Resp/Management<br>0111: Pdelay_Resp_Follow_Up/Signaling<br>1xxx: Reserved                                                                                                                 |
| Bit 7      | IPV6PR        | ro   | IPv6 packet received<br>When set to 1, this bit indicates that the received packet is an IPv6 packet.                                                                                                                                                                                                                                                             |
| Bit 6      | IPV4PR        | ro   | IPv4 packet received<br>When set to 1, this bit indicates that the received packet is an IPv4 packet.                                                                                                                                                                                                                                                             |
| Bit 5      | IPCB          | ro   | IP checksum bypassed<br>When set to 1, this bit indicates that the checksum offload engine is bypassed.                                                                                                                                                                                                                                                           |
| Bit 4      | IPPE          | ro   | IP payload error<br>When set to 1, this bit indicates that the 16-bit IP payload checksum (that is, the TCP, UDP or ICMP checksum) that the core calculated does not match the corresponding checksum filed in the received segment. It is also set to 1 when the TCP, UDP or ICMP segment length does not match the payload length value in the IP header field. |
| Bit 3      | IPHE          | ro   | IP header error<br>When set to 1, this bit indicates that the 16-bit IPv4 header checksum calculated by the core does not match the received checksum bytes, or that the IP datagram version is not consistent with the Ethernet Type value.                                                                                                                      |
| Bit 2: 0   | IPPT          | ro   | IP payload type<br>If IPv4 checksum offload is activated (IPCO=1, ETH_MACCR bit 10), these bits indicate the type of payload encapsulated in the IP datagram. These bits are "00" if there is an IP header orrr or fragmented IP.<br>000: Unknown or did not process IP payload<br>001: UDP<br>010: TCP<br>011: ICMP<br>1xx: Reserved                             |

**RDES6: Receive descriptor word 6**

RDES6 contains the 16 least significant bits of the time stamp

| Bit       | Name | Type | Description                                                                                                                                                                                                                                                                                   |
|-----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | RTSL | rw   | The DMA updates this field with the 32 least significant bits of the time stamp captured for the corresponding receive frame. The DMA updates this field only when the time stamp is enabled and the LS bit is set to 1 (that is, the last segment of the frame is stored in the buffer area) |

**RDES7: Receive descriptor word 7**

RDES7 contains the 16 most significant bits of the time stamp

| Bit       | Name | Type | Description                                                                                                                                                                                                                                                                                  |
|-----------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | RTSH | rw   | The DMA updates this field with the 32 most significant bits of the time stamp captured for the corresponding receive frame. The DMA updates this field only when the time stamp is enabled and the LS bit is set to 1 (that is, the last segment of the frame is stored in the buffer area) |

## 26.2.4 Enter and wake up EMAC power-down mode

The EMAC enters power-off mode when the PD bit is enabled in the EMAC\_MACPMTCTRLSTS register. In this mode, all received frames are dropped by the EMAC and they are not forwarded to the application. PMT supports the reception of remote wakeup frames and AMD Magic Packet frames and uses them to wake up the EMAC from power-off mode. This is done by setting the ERWF and EMP bits in the EMAC\_MACPMTCTRLSTS register.

### Remote wakeup frame filter register

There are eight wakeup frame filter registers, each of which requires to be configured one by one. The desired values of the wakeup frame filter are loaded by sequentially loading eight times the wakeup frame filter register. The read operation is identical to the write operation. To read the eight values, the user has to read the wakeup frame filter register for consecutive eight times.

Figure 26-13 Wakeup frame filter register

|                   |                    |              |                 |              |                 |              |                 |              |  |  |  |  |
|-------------------|--------------------|--------------|-----------------|--------------|-----------------|--------------|-----------------|--------------|--|--|--|--|
| Wkuppkfilter_reg0 | Filter 0 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg1 | Filter 1 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg2 | Filter 2 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg3 | Filter 3 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg4 | RESD               | Filter 3 Cmd | RESD            | Filter 2 Cmd | RESD            | Filter 1 Cmd | RESD            | Filter 0 Cmd |  |  |  |  |
| Wkuppkfilter_reg5 | Filter 3 Offset    |              | Filter 2 Offset |              | Filter 1 Offset |              | Filter 0 Offset |              |  |  |  |  |
| Wkuppkfilter_reg6 | Filter 1 CRC-16    |              |                 |              | Filter 0 CRC-16 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg7 | Filter 3 CRC-16    |              |                 |              | Filter 2 CRC-16 |              |                 |              |  |  |  |  |

#### Filter i byte mask

This register defines which bytes of the filter  $i$  ( $i=0\sim3$ ) are used to determine whether or not the frame is a wakeup frame. The bit 31 must be zero. The bit  $j[30: 0]$  is the byte mask. If the bit  $j$  is set, then filter  $i$  offset +  $j$  of the incoming frame will be processed by the CRC block; otherwise filter  $i$  offset +  $j$  is ignored.

#### Filter i command

This is a 4-bit command. Bit 3 defines the address type. When the bit is set, this feature applies to only multicast addresses. When the bit is cleared, this feature applies to only unicast addresses. Bit 2 and bit 1 are reserved. Bit 0 is the filter enable bit. This filter is disabled if the bit 0 is cleared.

#### Filter i offset

This is an 8-bit register that defines the offset for the filter  $i$  first byte to be examined by filter  $i$ . The minimum allowed is 12, which refers to the 13<sup>th</sup> byte of the frame (offset value 0 means the first byte of the frame)

#### Filter i CRC-16

This register contains the CRC\_16 value calculated by the filter, and the byte mask value programmed in the wakeup frame filter register block.

#### Remote wakeup frame detection

This mode is enabled by setting the RRWF bit in the EMAC\_MACPMTCTRLSTS register.

PMT supports four programmable filters. If the incoming frame passed the address filtering of the filter, and if the filter CRC\_16 matches the examined incoming frame, then the wakeup frame is received. PMT is only responsible for checking length error, FCS error, Dribble bit error, MII error, collision and ensuring that the wakeup frame is not a runt frame.

When a remote wakeup frame is received, the EMAC will move from sleep mode to normal mode. At the

same time, the RRWF bit (bit 6) is set in the EMAC\_MACPMTCTRLSTS register, indicating that a remote wakeup frame is received. If a remote wakeup interrupt is enabled, an interrupt will be generated when the PMT receives the remote wakeup frame.

### Magic Packet detection

Magic Packet detection is enabled by setting the EMP bit in the EMAC\_MACPMTCTRLSTS register. The Magic Packet frame contains a specific packet of information that is used to wakeup the stations on the LAN.

Magic Packet frame format: 6 bytes are all 1, followed by a MAC address repeating 16 times, for instance, MAC address of a device is 0x11aabb22cc33, then the Magic Packet used to wake up this frame is shown as follows:

Destination address source address .....FFFF FFFF FFFF  
11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33  
11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33  
11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33  
11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33 11aa bb22 cc33  
... CRC

In Sleep mode, the PMT will constantly detect each frame transferred to the station to determine whether or not the frame meets the Magic Packet format.

When the Magic Packet is received, the RMP bit will be updated in the EMAC\_MACPMTCTRLSTS register. Upon the reception of Magic Packet, the PMT will generate an interrupt if enabled.

### Precautions on system in DEEPSLEEP mode

In DEEPSLEEP mode, the Ethernet PMT block is still able to detect frames as long as the EXTI 19 is enabled. However, the RE bit has to be set in the EMAC\_MACCTRL register because the EMAC needs to detect Magic Packet or a remote wakeup frame.

DEEPSLEEP and wakeup sequences are recommended as follows:

1. Disable the TXDMA and wait for all data transmission to complete. These transmissions can be checked by polling the TI bit in the EMAC\_DMASTS register.
2. Disable the MAC transmitter and MAC receiver by clearing the TE and RE bits in the EMAC\_MACCTRL register.
3. Poll the RI bit in the EMAC\_DMASTS register, and wait for the RXDMA to real all the frames in the RXFIFO, and then disable the RXDMA.
4. Configure and enable the EXTI19 to generate either an event or an interrupt.
5. Enable Magic Packet/remote wakeup frame detection by setting the EMP/ERWF bit in the EMAC\_MACPMTCTRLSTS register.
6. Enable power-down mode by setting the PD bit in the MAC\_MACPMTCTRLSTS register.
7. Enable the EMAC receiver by setting the RE bit in the EMAC\_MACCTRL register.
8. MCU enters DEEPSLEEP mode.
9. Upon receiving Magic Packet/a remote wakeup frame, the Ethernet exits the power-down mode.
10. Read the EMAC\_MACPMTCTRLSTS register to clear RRWF/RMP, enable the EMAC transmit state machine, and the TXDMA and RXDMA.
11. Configure the MCU system clock.

## 26.2.5 IEEE1588 precision time protocol

The PTP is used to synchronize systems that include clocks of varying precision, resolution and stability (not limited to Ethernet). Refer to IEEE1588 standard for more information.

The PTP block captures the accurate time when a PTP packet is transmitted or received from Ethernet port, and the captured time is returned to the application.

### Reference clock source

According to IEEE158 standard, the system requires a reference time in a 64-bit format as the current time record, with the upper 32 bits time information in seconds, and the lower 32 bits time information in nanoseconds.

The PTP reference clock is used to generate the system time and to capture time stamps. The frequency of this reference clock must be greater or equal to the resolution of time stamp counter. The synchronization accuracy between the master node and the slave node is around 100ns.

The time synchronization accuracy depends on the PTP reference clock input period, the frequency drift of the crystal oscillator and that of the synchronization procedure.

### Transmission and reception of frames with PTP feature

When the bit 0 is set in the EMAC\_PTPTSCTRL register and the bit 25 is also set in the TDES0 register, a frame's SFD is output on the MII, and then a time stamp is captured. The upper 32 bits and the lower 32 bits of the time stamp are stored in the TDES3 and TDES2, respectively so that the time stamp and transmit status work will be returned to the application all together.

When the bit 0 is set in the EMAC\_PTPTSCTRL register and the bit 8 is also set in the EMAC\_PTPTSCTRL register, the EMAC will capture the time stamp of all the received frames on the MII. The upper 32 bits and the lower 32 bits of the time stamp are stored in the RDES3 and RDES2, respectively so that the time stamp and receive status work will be returned to the application all together.

### System time correction methods

The PTP input reference clock is the system clock SYSCLK, which is used to update the 64-bit time stamp of the Ethernet frames being transmitted or received. There are two correction methods: coarse and fine correction.

Coarse correction: the initial value/the offset value is written to the time stamp update registers (EMAC\_PTPTSHUD and EMAC\_PTPTSLUD). When the TI bit is set in the EMAC\_PTPTSCTRL register, an initialization process starts, and system clock counter is updated with the value in the time stamp update register. If the TU bit is set in the EMAC\_PTPTSCTRL register, a correction process starts, and the time stamp update register value is used as the offset value, and such offset value is added or subtracted from the system time.

Fine correction: the slave clock (reference clock) frequency drift with respect to the master clock (as defined in IEEE1588) is corrected over a period of time. An accumulator sums up the value of the addend register as shown in Figure 26-15. The pulse generated by the arithmetic carry of the accumulator is used to increment the system time counter. The addend register value depends on the system clock frequency. Both the accumulator and the addend are 32-bit registers.

Figure 26-14 System time update using the fine correction method



The subsecond register update frequency requires 50 MHz to achieve 20 ns accuracy for the system clock update circuit. Therefore, if the system clock frequency is 70 MHz, the ratio is calculated as  $70/50=1.4$ . Thus the value written to the addend register is  $2^{32}/1.4$ , which is equal to 0XB6DB6DB6.

The value in the addend register has to be updated according to the drift of the system clock frequency. If the subsecond register update frequency is 50 MHz, the constant value used to increment the subsecond register is  $2^{31}/(50*10^6)=43$ .

The software has to calculate the drift of the frequency by means of Sync, and to update the accumulator register accordingly. Initially, the slave clock addend register is programmed to be FreqCompensationValue0:

$\text{FreqCompensationValue0} = 2^{32}/\text{frequency division ratio}$ . If the MasterToSlaveDelay is assumed to be the same for consecutive Sync messages. The algorithm below mentioned must be applied. After a few Sync cycles, the frequency is locked. The slave clock can then determine an accurate MasterToSlaveDelay value and synchronize the master with the slave clock using the new value. The algorithm is shown as follows:

When the master clock is  $\text{MasterSyncTime}_n$ , the master node sends the slave node a Sync message. The slave node receives this message when its local clock is  $\text{SlaveClockTime}_n$ , and computes  $\text{MasterClockTime}_n$  as

$$\text{MasterClockTime}_n = \text{MasterSyncTime}_n + \text{MasterToSlaveDelay}_n$$

The master clock count for the current Sync cycle,  $\text{MasterClockCount}_n$  is:

$$\text{MasterClockCount}_n = \text{MasterClockTime}_n - \text{MasterClockTime}_{n-1}, \text{ assuming that the MasterToSlaveDelay is the same for Sync cycles } n \text{ Sync cycles } n-1$$

The slave clock count for the current Sync cycle,  $\text{SlaveClockCount}_n$  is:

$$\text{SlaveClockCount}_n = \text{SlaveClockTime}_n - \text{SlaveClockTime}_{n-1}$$

The difference between the master clock count and slave clock count for the current Sync cycle,  $\text{ClockDiffCount}_n$  is

$$\text{ClockDiffCount}_n = \text{MasterClockCount}_n - \text{SlaveClockCount}_n$$

The frequency-ratio factor for a slave clock,  $\text{FreqScaleFactor}_n$  is

$$\text{FreqScaleFactor}_n = (\text{MasterClockCount}_n + \text{ClockDiffCount}_n) / \text{SlaveClockCount}_n$$

The frequency compensation value for the addend register,  $\text{FreqCompensationValue}_n$  is

$$\text{FreqCompensationValue}_n = \text{FreqScaleFactor}_n \times \text{FreqCompensationValue}_{n-1}$$

This algorithm comes with a self-correction feature. In theory, the frequency can be locked at a synchronized cycle. However, it may make several cycles to synchronize the slave device.

### System time initialization procedure

1. Mask the time stamp trigger interrupt by setting the bit 9 in the EMAC\_MAIMR register.
2. Enable the time stamp by setting the bit 0 in the EMAC\_PTPTSCTRL register.
3. Program the subsecond increment register based on the system time update precision.
4. If the fine correction method is being used, program the EMAC\_PTPTSAD register, set the bit 5 in the EMAC\_PTPTSCTRL register, poll the EMAC\_PTPTSCTRL register until the bit 5 becomes 0. For the coarse correction method, skip this step and directly jump to step 6.
5. To select the fine correction method, program the bit 1 in the EMAC\_PTPTSCTRL register.
6. Write the system time value to be configured to the EMAC\_PTPTSHUD and EMAC\_PTPTSLUD registers.
7. Set the bit 2 in the EMAC\_PTPTSCTRL register, and start initializing the time stamp and polling this bit until this bit becomes 0 (initialization complete).
8. The time stamp counter starts running as soon as the initialization is complete.
9. Enable the MAC transmitter and receiver for proper time stamping.

### Programming steps for system time update using coarse correction method

1. Write the offset value (positive or negative) to the Ethernet PTP time stamp high update register (EMAC\_PTPTSHUD) and the Ethernet PTP time stamp low update register (EMAC\_PTPTSLUD).
2. Set the bit 3 (TU) in the Ethernet PTP time stamp control register (EMAC\_PTPTSCTRL).
3. When the TU bit is cleared, the value in the time stamp update registers is added to or subtracted from the system time.

### Programming steps for system time update using fine correction method

1. Use the algorithm explained in System time correction methods to calculate the value of the addend register.
2. Update the addend register.
3. Write the target value you want to the target time high and target time low registers, and clear the bit 9 in the Ethernet MAC interrupt mask register (EMAC\_MAIMR) to activate the time stamp interrupt.
4. Set the bit 4 (TITE) in the Ethernet PTP time stamp control register (EMAC\_PTPTSCTRL).
5. When this event generates an interrupt, read the EMAC\_MAIMR register to clear the corresponding interrupt flag bits.
6. Reprogram the EMAC\_PTPTSAD register with the old value and set the bit 5 in the EMAC\_PTPTSCTRL register to update the addend register.

### PTP trigger internal connection with TMR2

The EMAC provides a trigger interrupt when the system time is greater than the target time. Using an interrupt introduces an interrupt latency. To obtain an accurate interrupt latency time, a PTP will output a high signal to the TMR2 when the system time becomes greater than the target value. An accurate interrupt latency can be calculated since the clock of the timer and PTP reference clock are synchronous.

Set the bit [11:10]=01 in the TMR2\_RMP register to enable the connection between the PTP trigger signal and the TMR2 IS1.

Figure 26-15 PTP trigger output to TMR2 ITR1 connection



### PTP second pulse output signal

Refer to the EMAC\_PTPPPSCR register descriptor for more information about PTP pulse second output. The following contents are based on the fact when the emac\_pps\_sel bit (bit 9) is cleared in the CRM\_MISC2 register.

The PPS output frequency is 1 Hz by default, which can be configured to 2PPSFREQ Hz through the PPSFREQ[3: 0] in the EMAC\_PTPPPSCR register.

If it is 1 Hz, the pulse width of the PPS is 125 ms when the binary rollover control is selected (TSSSR=0 in the EMAC\_PTPTSCTRL register); the pulse width of the PPS is 100 ms when the digital rollover control is selected (TSSSR=1).

If it is 2 Hz or over, the duty cycle of the PPS output is 50% when the binary rollover control is selected. Configure the PB5 multiplexed feature to enable PPS output feature.

Figure 26-16 PPS output



### 26.2.6 EMAC interrupts

The EMAC has two interrupt vectors: one is used for normal Ethernet operations and the other for the Ethernet wakeup event (remote wakeup frame or Magic Packet detection) when it is mapped on EXINT line 19.

The first interrupt vector is used for interrupts generated by the MAC and the DMA.

The second interrupt vector is used for interrupts generated by the PMT block on wakeup events. It can cause the AT32F437xx to exit the low-power mode, and generate an interrupt.

When an Ethernet wakeup event is mapped on the EXINT line19 and the EMAC PMT interrupt is enabled and the EXINT line 19 interrupt, detected on its rising edge, is also enabled, both interrupts are generated at the same time.

Figure 26-17 Ethernet interrupts



## 26.3 EMAC registers

Table 26-8 shows the Ethernet register map and its reset values.

The peripheral registers can be accessed by bytes (8-bit), half words (16-bit) or words (32-bit).

Table 26-8 Ethernet register map and its reset values

| Register           | Offset | Reset value |
|--------------------|--------|-------------|
| EMAC_MACCTRL       | 0x00   | 0x0000 8000 |
| EMAC_MACFRMF       | 0x04   | 0x0000 0000 |
| EMAC_MACHTH        | 0x08   | 0x0000 0000 |
| EMAC_MACHTL        | 0x0C   | 0x0000 0000 |
| EMAC_MACMIIADDR    | 0x10   | 0x0000 0000 |
| EMAC_MACMIIDT      | 0x14   | 0x0000 0000 |
| EMAC_MACFCTRL      | 0x18   | 0x0000 0000 |
| EMAC_MACVLT        | 0x1C   | 0x0000 0000 |
| EMAC_MACRWFF       | 0x28   | 0x0000 0000 |
| EMAC_MACPMTCTRLSTS | 0x2C   | 0x0000 0000 |
| EMAC_MACISTS       | 0x38   | 0x0000 0000 |

|                 |        |             |
|-----------------|--------|-------------|
| EMAC_MAIMR      | 0x3C   | 0x0000 0000 |
| EMAC_MACA0H     | 0x40   | 0x0010 FFFF |
| EMAC_MACA0L     | 0x44   | 0xFFFF FFFF |
| EMAC_MACA1H     | 0x48   | 0x0000 FFFF |
| EMAC_MACA1L     | 0x4C   | 0xFFFF FFFF |
| EMAC_MACA2H     | 0x50   | 0x0000 FFFF |
| EMAC_MACA2L     | 0x54   | 0xFFFF FFFF |
| EMAC_MACA3H     | 0x58   | 0x0000 FFFF |
| EMAC_MACA3L     | 0x5C   | 0xFFFF FFFF |
| EMAC_MMCTRL     | 0x100  | 0x0000 0000 |
| EMAC_MMCR1      | 0x104  | 0x0000 0000 |
| EMAC_MMCTI      | 0x108  | 0x0000 0000 |
| EMAC_MMCRIM     | 0x10C  | 0x0000 0000 |
| EMAC_MMCTIM     | 0x110  | 0x0000 0000 |
| EMAC_MMCTFSCC   | 0x14C  | 0x0000 0000 |
| EMAC_MMCTFMSCC  | 0x150  | 0x0000 0000 |
| EMAC_MMCTFCNT   | 0x168  | 0x0000 0000 |
| EMAC_MMCRFECNT  | 0x194  | 0x0000 0000 |
| EMAC_MMCRFAECNT | 0x198  | 0x0000 0000 |
| EMAC_MMCRGUFCNT | 0x1C4  | 0x0000 0000 |
| EMAC_PTPTSCTRL  | 0x700  | 0x0000 2000 |
| EMAC_PTPSSINC   | 0x704  | 0x0000 0000 |
| EMAC_PTPTSH     | 0x708  | 0x0000 0000 |
| EMAC_PTPTSL     | 0x70C  | 0x0000 0000 |
| EMAC_PTPTSH     | 0x708  | 0x0000 0000 |
| EMAC_PTPTSL     | 0x70C  | 0x0000 0000 |
| EMAC_PTPTSHUD   | 0x710  | 0x0000 0000 |
| EMAC_PTPTSLUD   | 0x714  | 0x0000 0000 |
| EMAC_PTPTSAD    | 0x718  | 0x0000 0000 |
| EMAC_PTPTTH     | 0x71C  | 0x0000 0000 |
| EMAC_PTPTTL     | 0x720  | 0x0000 0000 |
| EMAC_PTPTSSR    | 0x728  | 0x0000 0000 |
| EMAC_PTPPPSCR   | 0x72c  | 0x0000 0000 |
| EMAC_DMABM      | 0x1000 | 0x0002 0101 |
| EMAC_DMATPD     | 0x1004 | 0x0000 0000 |
| EMAC_DMARPD     | 0x1008 | 0x0000 0000 |
| EMAC_DMARDLADDR | 0x100C | 0x0000 0000 |
| EMAC_DMATDLADDR | 0x1010 | 0x0000 0000 |
| EMAC_DMASTS     | 0x1014 | 0x0000 0000 |
| EMAC_DMAOPM     | 0x1018 | 0x0000 0000 |
| EMAC_DMAIE      | 0x101C | 0x0000 0000 |

|                 |        |             |
|-----------------|--------|-------------|
| EMAC_DMAMFBOCNT | 0x1020 | 0x0000 0000 |
| EMAC_DMACTD     | 0x1048 | 0x0000 0000 |
| EMAC_DMACRD     | 0x104C | 0x0000 0000 |
| EMAC_DMACTBADDR | 0x1050 | 0x0000 0000 |
| EMAC_DMACRBADDR | 0x1054 | 0x0000 0000 |

### 26.3.1 Ethernet MAC configuration register (EMAC\_MACCTRL)

The Ethernet MAC configuration register defines the receive and transmit operation modes.

A delay greater than 4μs is required for two consecutive write accesses to this register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 23     | WD       | 0x0         | rw   | <p>Watchdog Disable<br/>When this bit is set, the MAC disables the watchdog timer on the receiver, and can receive frames of up to 16,384 bytes.<br/>When this bit is cleared, the MAC allows no more than 2048 bytes of the frames being received.</p>                                                                                                                                                                                        |
| Bit 22     | JD       | 0x0         | rw   | <p>Jabber Disable<br/>When this bit is set, the MAC disables the Jabber timer on the transmitter, and can transfer frames of up to 16,384 bytes.<br/>When this bit is cleared, the MAC cuts off the transmitter if the application sends out more than 2048 bytes of data during transmission.</p>                                                                                                                                             |
| Bit 21: 20 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 19: 17 | IFG      | 0x0         | rw   | <p>InterFrame Gap<br/>These bits are used to define the minimum interframe gap between frames during transmission.<br/>000: 96 bit times      96 bit times<br/>001: 88 bit times      88 bit times<br/>010: 80 bit times      80 bit times<br/>...<br/>111: 40 bit times      40 bit times<br/>In half-duplex mode, the minimum IFG can be configured as 64 bit times (IFG=100). Lower values are not allowed.</p>                             |
| Bit 16     | DCS      | 0x0         | rw   | <p>Disable Carrier Sense<br/>When this bit is set, the MAC transmitter will ignore the MII CRS signal during frame transmission in half-duplex mode. No error is reported due to loss of carrier or no carrier during transmission.<br/>When this bit is cleared, the MAC transmitter will report errors due to carrier sense and even abort the transmission.<br/>This bit is reserved in full-duplex mode.</p>                               |
| Bit 15     | Reserved | 0x1         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 14     | FES      | 0x0         | rw   | <p>Fast EMAC Speed<br/>This bit indicates the speed of the MII, RMII interface.<br/>0: 10 Mbps<br/>1: 100 Mbps</p>                                                                                                                                                                                                                                                                                                                             |
| Bit 13     | DRO      | 0x0         | rw   | <p>Disable Receive Own<br/>When this bit is set, the MAC disables the frame reception in half-duplex mode if the phy_txen_o is enabled.<br/>When this bit is cleared, the MAC will receive all packets that are given by the PHY during transmission.<br/>This bit is not applicable when the MAC is in full-duplex mode.<br/>This bit is reserved (with default value RO) when the MAC is configured as "For full-duplex mode only" mode.</p> |
| Bit 12     | LM       | 0x0         | rw   | <p>Loopback Mode<br/>When this bit is set, the MAC MII operates in loopback</p>                                                                                                                                                                                                                                                                                                                                                                |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | mode. The MII receive clock input (clk_rx_i) is required for the loopback mode to work normally, for the transmit clock is not looped-back internally.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 11   | DM       | 0x0 | rw   | <p>Duplex Mode</p> <p>When this bit is set, the MAC operates in full-duplex mode, in which it can transmit and receive simultaneously.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 10   | IPC      | 0x0 | rw   | <p>IPv4 Checksum</p> <p>When this bit is set, the MAC calculates the 16-bit complement sum of all received Ethernet frames and enables IPv4 header checksum (assuming it is bytes 26-26 or 29-30 (VLANtagged)) for received frames, and gives the status in the receive status information.</p> <p>The MAC also appends the 16-bit checksum of the calculated IP header packets (bytes after the IPv4header ), and adds it to the Ethernet frame that has been sent out to the application (when Type 2 COE is deselected).</p> <p>When this bit is cleared, this feature is disabled.</p> <p>When this bit is set, IPv4 header checksum feature and IPv4 or IPv6 TCP, UDP or ICMP payload checksum feature is enabled while the Type 2 COE is selected. When this bit is cleared, the COE function in the receiver is disabled, and the corresponding PCE and IP HCE status bits are always 0. This bit is reserved (with default value RO) if the IP checksum mechanism is disabled during the core configuration.</p> |
| Bit 9    | DR       | 0x0 | rw   | <p>Disable Retry</p> <p>When this bit is set, the MAC attempts only 1 transmission. When a collision occurs on the MII interface, the MAC will ignore the current frame transmission and report a frame abort because of excessive collision error in the transmit frame status.</p> <p>When this bit is cleared, the MAC attempts retries based on the settings of BL ([6: 5]). This bit is applicable only in half-duplex mode. It is reserved (with default value RO) in "For full-duplex mode only" mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 8    | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 7    | ACS      | 0x0 | rw   | <p>Automatic pad/CRC Stripping</p> <p>When this bit is set, the MAC strips the pad/FCS field on received frames only when the frame length is shorter than 1536 bytes. All received frame with length field greater than or equal to 1536 bytes are passed on to the application without stripping the Pad or FCS field.</p> <p>When this bit is cleared, the MAC will forward all received frames to the master without changing its contents.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 6: 5 | BL       | 0x0 | rw   | <p>Back-off Limit</p> <p>The Back-off limit defines the random integer number (r) of slot time delays (512 bit times for 10/100 Mbps) the MAC waits before retries after a collision. This field is applicable only in the half-duplex mode. It is reserved (RO) in "For full-duplex mode only" mode.</p> <p>00: k= min (n, 10)<br/>     01: k = min (n, 8)<br/>     10: k = min (n, 4)<br/>     11: k = min (n, 1)</p> <p>Where n = the number of slot time delays for retransmission attempt, and r takes the random integer value in the range <math>0 \leq r &lt; 2k</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 4    | DC       | 0x0 | rw   | <p>Deferral Check</p> <p>When this bit is set, the deferral check function is enabled in the MAC. The MAC issues a frame abort status and sets the excessive deferral error flag bit in the transmit frame status when the transmit state machine is delayed for more than 24288 bit times in 10/100 Mbit/s mode.</p> <p>If the Jumbo frame mode is enabled in 10/100 Mbps mode,</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | the deferral threshold is 155680 bit times. Deferral begins when the transmitter is ready to transmit, but is prevented when an active carrier sense signals is detected on the MII. Deferral time is not cumulative. For instance, if the transmitter is deferred for 10000 bit times because that the CRS signals is active first, but then becomes inactive, then transmits, collides, backs off because of collision, and then has to defer again after the completion of back-off, the deferral times resets to 0 and restarts. |
|          |          |     |      | When this bit is cleared, the deferral check function is disabled. The MAC defers until the CRS signal becomes inactive. This bit is applicable only in the half-duplex mode. It is reserved (RO) in "For full-duplex mode only" mode.                                                                                                                                                                                                                                                                                               |
| Bit 3    | TE       | 0x0 | rw   | Transmitter Enable<br>When this bit is set, the transmit state machine of the MAC is enabled. When this bit is cleared, the MAC disables the transmit state machine after the completion of the current frame transmission, and does not transmit any further frames (To modify this bit through consecutive commands, if needed, a deferral value greater than 4us is required between two consecutive operations)                                                                                                                  |
| Bit 2    | RE       | 0x0 | rw   | Receiver Enable<br>When this bit is set, the receive state machine of the MAC is enabled. When this bit is cleared, the MAC disables the receive state machine after the completion of the current frame reception, and does not receive any further frames (To modify this bit through consecutive commands, if needed, a deferral value greater than 4us is required between two consecutive operations).                                                                                                                          |
| Bit 1: 0 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 26.3.2 Ethernet MAC frame filter register (EMAC\_MACFRMF)

The Ethernet MAC frame filter register contains the filter control bits for receiving frames. Some of the control bits go to the address check block of the MAC to perform the first level of address filtering.

The second level of filtering is performed on the incoming frames based on other control bits (such as pass bad frames and pass control frames).

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | RA       | 0x0         | rw   | Receive All<br>When this bit is set, the MAC passes all received frames onto the application, irrespective of whether they have passed through the address filter. The result (pass or fail) of the source address or destination address filtering is updated in the corresponding bits of the receive status word. When this bit is cleared, the MAC passes on to the application only those frames that have passed the source address or destination address filtering. |
| Bit 30: 11 | Reserved | 0x00000     | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 10     | HPF      | 0x0         | rw   | Hash or Perfect Filter<br>When this bit is set, the address filter passes frames that match the perfect filter or hash filter set by the HMC or HUC bit.<br>When this bit is cleared, if the HUC or HMC bit is set, only frames that match the hash filter can pass address filter.                                                                                                                                                                                         |
| Bit 9      | SAF      | 0x0         | rw   | Source Address Filter<br>When this bit is set, the MAC compares the source address of the received frame with the value programmed in the enabled source address registers. If the comparison mismatches, the MAC will drop this frame.<br>(SAF). When this bit is cleared, the MAC forwards the received frame to the application and updates the source address filter bit (SAF) in the receive status based on the source address comparison.                            |
| Bit 8      | SAIF     | 0x0         | rw   | Source Address Inverse Filtering                                                                                                                                                                                                                                                                                                                                                                                                                                            |

|          |      |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |      |     |    | When this bit is set, the address check block operates in inverse filtering mode. The frame whose source address matches the source address register is marked as failing the source address filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|          |      |     |    | When this bit is cleared, the frame whose source address does not match the source address register is marked as failing the source address filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 7: 6 | PCF  | 0x0 | rw | <p>Pass Control Frames</p> <p>These bits control the forwarding of all control frames (including unicast and multicast Pause frames).</p> <p>00: MAC filters all control frames and prevents them from reaching the application</p> <p>01: MAC forwards all control frames, except Pause frame, to the application even if they fail the address filter</p> <p>10: MAC forwards all control frames to the application even if they fail the address filter</p> <p>11: MAC forwards control frames that pass the address filter to the application</p> <p>The following conditions must be met when dealing with a Pause frame:</p> <ol style="list-style-type: none"> <li>1: When the MAC is in full-duplex mode, the bit 2 (REF) is set in the register 6 (flow control register) to enable flow control.</li> <li>2: When the bit 3 (UP) is set in the register 6 (flow control register), the destination address of the received frames matches the specific multicast address or MAC address 0.</li> <li>3: Type field of the receive frame is 0x8808, and the OPCODE field is 0x0001.</li> </ol> |
| Bit 5    | DBF  | 0x0 | rw | <p>Disable Broadcast Frames</p> <p>When this bit is set, the address filters filter all incoming broadcast frames. In addition, all other filter settings will also be overwritten.</p> <p>When this bit is set, the address filters pass all incoming broadcast frames.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 4    | PMC  | 0x0 | rw | <p>Pass MultiCast</p> <p>When this bit is set, all frames with a multicast destination address (first bit in the destination address is set) are passed.</p> <p>When this bit is cleared, the filtering of a multicast frame depends on the HMC bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 3    | DAIF | 0x0 | rw | <p>Destination Address Inverse Filtering</p> <p>When this bit is set, the address check block operates in inverse filtering mode for the destination address comparison for both unicast and multicast frames.</p> <p>When this bit is cleared, the filter work normally.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 2    | HMC  | 0x0 | rw | <p>Hash MultiCast</p> <p>When this bit is set, the MAC performs destination address filtering of the received multicast frames according to the hash table.</p> <p>When this bit is cleared, the MAC performs a perfect destination address filtering for multicast frames, that is, it compares the destination address field with the values programmed in the destination registers.</p> <p>This bit is reserved if Hash filter is not selected during core configuration.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 1    | HUC  | 0x0 | rw | <p>Hash UniCast</p> <p>When this bit is set, the MAC performs destination address filtering for unicast frames according to the hash table.</p> <p>When this bit is cleared, the MAC performs a perfect destination address filtering for unicast frames, that is, it compares the destination address field with the values programmed in the destination registers.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 0    | PR   | 0x0 | rw | Promiscuous Mode<br>When this bit is set, the address filters pass all incoming frames regardless of their destination or source address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

When the PR is set, the source address or destination address error bits in the receive status word are always 0.

### 26.3.3 Ethernet MAC Hash table high register (EMAC\_MACHTH)

The 64-bit Hash table is used for group address filtering. For Hash filtering, the contents of the destination address of the incoming frame pass through the CRC logic, and the upper 6 bits in the CRC register are used to index the Hash table. The most significant bit of the CRC determines the register to be used (EMAC\_MACHTH or EMAC\_MACHTL), and the other 5 bits determine which bit in the register is to be used. The Hash value 5b'00000 uses the bit 0 in the selected register, while the Hash value 5b'11111 uses the bit 31 in the selected register.

The Hash value of the destination address is calculated according to the following steps:

1. Calculate a 32-bit CRC value of the destination address (see IEEE 802.3, and refer to 3.2.8 section for more details)
2. Bit invert the value obtained in Step 1
3. Take the upper 6 bits from the values obtained in Step 2

For example, if the destination address of the incoming frame is 0x1F52419CB6AF (0x1F is the first byte received on the MII interface), the calculated 6-bit Hash value is 0x2C and the bit 12 in the EMAC\_MACHTH registers checked for filtering. If the destination address of the incoming frame is 0xA00A98000045, the calculated 6-bit Hash value is 0x07, and the bit 7 in the EMAC\_MACHTL register is checked for filtering.

| Bit    | Name | Reset value | Type | Description                                            |
|--------|------|-------------|------|--------------------------------------------------------|
| Bit 31 | HTH  | 0x0000 0000 | rw   | This bit contains the upper 32 bits of the Hash table. |

### 26.3.4 Ethernet MAC Hash table low register (EMAC\_MACHTL)

The EMAC\_MACHTL register contains the lower 32 bits of the Hash table. If the Hash filter is disabled or either 128-bit or 256-bit Hash table is selected, both register 2 and register 3 are reserved.

| Bit    | Name | Reset value | Type | Description                                                              |
|--------|------|-------------|------|--------------------------------------------------------------------------|
| Bit 31 | HTL  | 0x0000 0000 | rw   | Hash Table Low<br>This bit contains the lower 32 bits of the Hash table. |

### 26.3.5 Ethernet MAC MII address register (EMAC\_MACMIIADDR)

The Ethernet MAC MII address register controls the external PHY through the management interface.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 15: 11 | PA       | 0x00        | rw   | PHY Address<br>This field indicates which of the 32 possible PHY devices are being accessed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 10: 6  | MII      | 0x00        | rw   | MII Register<br>This field select the desired MII register in the PHY device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 5: 2   | CR       | 0x0         | rw   | Clock Range<br>The CSR clock range selection determines the MDC clock frequency based on the used CSR clock frequency.<br>Each value (when bit 5=0) has its corresponding CSR clock frequency range in order to ensure that the MDC clock frequency is roughly between 1.0 MHz and 2.5 MHz.<br>0000: CSR clock frequency is 60–100 MHz, and MDC clock frequency is CSR clock/42<br>0001: CSR clock frequency is 100–150 MHz, and MDC clock frequency is CSR clock/62<br>0010: CSR clock frequency is 20–35 MHz, and MDC clock frequency is CSR clock/16<br>0011: CSR clock frequency is 35–60 MHz, and MDC clock frequency is CSR clock/26<br>0100: CSR clock frequency is 150–250 MHz, and MDC clock frequency is CSR clock/102<br>0101: CSR clock frequency is 250–288 MHz, and MDC clock frequency is CSR clock/124<br>0110, 0111: Reserved |

|       |    |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|----|-----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 1 | MW | 0x0 | rw | <p><b>MII Write</b><br/>When this bit is set, it indicates that the EMAC_MACMIIIDT register is used for a write operation to the PHY.<br/>When this bit is not set, it is a read operation, and the data is loaded to the EMAC_MACMIIIDT register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 0 | MB | 0x0 | rw | <p><b>MII Busy</b><br/>This bit should read a logic 0 before writing to the EMAC_MACMIIADDR and EMAC_MACMIIIDT register. During a PHY register access, this bit is set to 1'b1 by software, indicating that a read or write access is in progress.<br/>The EMAC_MACMIIIDT register is invalid before this bit is cleared by the MAC. Thus, the MII data should be kept valid until this bit is cleared by the MAC during a PHY write operation. Similarly, the EMAC_MACMIIIDT value is invalid until this bit is cleared by the MAC during a PHY read operation.<br/>The previous operation must be completed before performing subsequent read or write operations. This is because that there will be no acknowledgement from PHY to MAC after the completion of a read or write operation, the function of this bit will not change even if the PHY is not present.</p> |

### 26.3.6 Ethernet MAC MII data register (EMAC\_MACMIIIDT)

The Ethernet MAC MII data register stores data to be written to the PHY register located at the address specified in the EMAC\_MACMIIADDR register. EMAC\_MACMIIIDT register also stores data read out from the PHY registers.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                 |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                  |
| Bit 15: 0  | MD       | 0x0000      | rw   | <p><b>MII Data</b><br/>This field contains the 16-bit value from the PHY after a read operation, or the 16-bit value to be written to the PHY before a write operation.</p> |

### 26.3.7 Ethernet MAC flow control register (EMAC\_MACFCTRL)

The Ethernet MAC flow control register controls the generation and reception of the control frames by the MAC flow control block. Writing 1 to the Busy bit triggers the flow control block to generate a Pause frame. The field of the control frame is selected as defined in the 802.3x specification, and the Pause Time value from this register is used in the Pause Time field of the control frame. The Busy bit remains set before the control frame is transferred onto the cable. The host must make sure that the Busy bit is cleared before writing to the register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | PT       | 0x0000      | rw   | <p><b>Pause Time</b><br/>This field contains the value to be used in the Pause Time field of the control frame. If the Pause Time bit is configured to be double-synchronized to the MII clock domain, then consecutive write operations to this register should be performed only after at least four clock cycles in the destination clock domain.</p> |
| Bit 15: 8  | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 7      | DZQP     | 0x0         | rw   | <p><b>Disable Zero-Quanta Pause</b><br/>When this bit is set, it disables the automatic generation of Zero-quanta Pause frame while the flow control signal of the FIFO layer is disabled.<br/>When this bit is cleared, normal operation resumes. The automatic generation of Zero-quanta Pause frame is enabled.</p>                                   |
| Bit 6      | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                               |
| Bit 5: 4   | PLT      | 0x0         | rw   | <p><b>Pause Low Threshold</b><br/>This field defines the threshold of the Pause timer.</p>                                                                                                                                                                                                                                                               |

|       |         |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|---------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     |         | The threshold values should always be less than the Pause time defined in the [31: 16] bit. For example, if PT = 100H (256 slot times), and PLT = 01, then a second Pause frame is automatically transmitted if initiated at 228 (256-28) slot times after the first Pause frame is transmitted.<br>Threshold selection as follows:<br>00: Pause time minus 4 slot times (PT minus 4 slot times)<br>01: Pause time minus 28 slot times (PT minus 28 slot times)<br>10: Pause time minus 144 slot times (PT minus 144 slot times)<br>11: Pause time minus 256 slot times (PT minus 256 slot times)<br>Slot time is defined as the time taken to transmit 512 bits (64 bytes) on the MII interface.                                                                                                                                                                                                                                                                                                                        |
| Bit 3 | DUP     | 0x0 | rw      | Detect Unicast Pause Frame<br>The Pause frame with a unique multicast address as specified in the IEEE 802.3 will be processed. When this bit is set, the MAC detects the Pause frames with a unicast address specified in the MAC address0 high and MAC address0 low registers.<br>When this bit is cleared, the MAC detects only a Pause frame with a unique multicast address.<br>Note: If the multicast address of the received frame does not match the unique multicast address, the MAC will not process the Pause frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 2 | ERF     | 0x0 | rw      | Enable Receive Flow control<br>When this bit is set, the MAC decodes the received Pause frame and disables the transmitter for a period of time. When this bit is cleared, the decode function of the Pause frame is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 1 | ETF     | 0x0 | rw      | Enable Transmit Flow control<br>In full-duplex mode, when this bit is set, the MAC enables the flow control operation to transmit Pause frames. When this bit is cleared, the flow control of the MAC is disabled, and the MAC does not transmit any Pause frames.<br>In half-duplex mode, when this bit is set, the MAC enables the back-pressure feature. When this bit is cleared, the back-pressure feature is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 0 | FCB/BPA | 0x0 | rw1c/rw | Flow Control Busy/Back Pressure Activate<br>In full-duplex mode, this bit initiates a Pause frame; in half-duplex mode, the back-pressure feature is activated if the TFE bit is set.<br>In full-duplex mode, this bit is read as 1'b0 before writing to the EMAC_MACFCTRL register. The application must set this bit to 1'b1 to initiate a Pause frame. During a control frame transmission, this bit remains set, indicating that a frame transmission is in progress. After the completion of the Pause frame, the MAC resets this bit to 1'b0. The Ethernet MAC flow control register (EMAC_MACFCTRL) should not be written until this bit is cleared.<br>In half-duplex mode, when this bit is set (and the TFE is set), the back-pressure feature is activated by the MAC. During back pressure, when the MAC receives a new frame, the transmitter starts sending a JAM mode, resulting a collision. When the MAC is configured to full-duplex mode, the back-pressure (BPA) function is automatically disabled. |

### 26.3.8 Ethernet MAC VLAN tag register (EMAC\_MACVLT)

The Ethernet MAC VLAN tag register contains the IEEE 802.1Q VLAN tag to identify the VLAN frames. The MAC compares the 13<sup>th</sup> and 14<sup>th</sup> bytes of the received frame (length/type) with 16'h8100, and the following 2 bytes are compared with the VLAN tag. If the comparison matches, the VLAN bit is set in the receive frame status. The legal length of the VLAN frame is increased from 1518 bytes to 1522 bytes.

If the EMAC\_MACVLT register is configured to be double-synchronized to the (G)MII clock domain, then consecutive write operations to this register should be performed at least four clock cycles in the destination clock domain.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 16     | ETV      | 0x0         | ro   | Enable 12-bit VLAN tag comparison<br>When this bit is set, a 12-bit VLAN identifier, rather than a 16-bit VLAN tag, is used for comparison and filtering. The bit [11: 0] of the VLAN tag is compared with the corresponding field in the received VLAN-tagged frame. Similarly, if enabled, only a 12-bit VLAN tag is used for hash VLAN filtering.<br>When this bit is cleared, the 16 bits of the received VLAN frame's 15 <sup>th</sup> and 16 <sup>th</sup> bytes are used for comparison and VLAN hash filtering.                                                                                                                                                                                                                 |
| Bit 15: 0  | VTI      | 0x0000      | rw   | VLAN Tag Identifier (for receive frames)<br>This field contains the 802.1Q VLAN tag to identify VLAN frames, which is compared with the 15 <sup>th</sup> and 16 <sup>th</sup> bytes of the received VLAN frames, described as follows:<br>Bit [15: 13]: User priority<br>Bit 12: Canonical format indicator (CFI) or drop eligible indicator (DEI)<br>Bit [11: 0]: VLAN tag's VLAN identifier field<br>When the ETV bit is set, only the VID ([11: 0]) is used for comparison. If the VL is all zero (if the ETV is set, then VL[11: 0] is all zero), the MAC does not check the 15 <sup>th</sup> and 16 <sup>th</sup> bytes for VLAN tag comparison, and treats all frames with a type field value of 0x8100 or 0x88a8 as VLAN frames. |

### 26.3.9 Ethernet MAC remote wakeup frame filter register (EMAC\_MACRWFF)

The PMT CSR sets the request wakeup events and detects the wakeup events.

Figure 26-18 Ethernet MAC remote wakeup frame filter register (EMAC\_MACRWFF)

|                   |                    |              |                 |              |                 |              |                 |              |  |  |  |  |
|-------------------|--------------------|--------------|-----------------|--------------|-----------------|--------------|-----------------|--------------|--|--|--|--|
| Wkuppkfilter_reg0 | Filter 0 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg1 | Filter 1 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg2 | Filter 2 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg3 | Filter 3 Byte Mask |              |                 |              |                 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg4 | RESD               | Filter 3 Cmd | RESD            | Filter 2 Cmd | RESD            | Filter 1 Cmd | RESD            | Filter 0 Cmd |  |  |  |  |
| Wkuppkfilter_reg5 | Filter 3 Offset    |              | Filter 2 Offset |              | Filter 1 Offset |              | Filter 0 Offset |              |  |  |  |  |
| Wkuppkfilter_reg6 | Filter 1 CRC-16    |              |                 |              | Filter 0 CRC-16 |              |                 |              |  |  |  |  |
| Wkuppkfilter_reg7 | Filter 3 CRC-16    |              |                 |              | Filter 2 CRC-16 |              |                 |              |  |  |  |  |

### 26.3.10 Ethernet MAC PMT control and status register (EMAC\_MACPMTCTRLSTS)

The Ethernet MAC PMT control and status register sets the request wakeup events and detects the wakeup events.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | RWFFPR   | 0x0         | rw1s | Remote Wakeup Frame Filter Register Pointer Reset<br>When this bit is set, it resets the remote frame filter register pointer to 3'b000. This bit is automatically cleared after one clock cycle.                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 30: 10 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 9      | GUC      | 0x0         | rw   | Global UniCast                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 8: 7   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 6      | RRWF     | 0x0         | rrc  | Received Remote Wakeup Frame<br>When this bit is set, it indicates that the power management event was generated because of the reception of a remote wakeup frame. This bit is cleared by a read access to this register.                                                                                                                                                                                                                                                                                                                                                 |
| Bit 5      | RMP      | 0x0         | rrc  | Received Magic Packet<br>When this bit is set, it indicates that the power management event is generated because of the reception of a Magic packet. This bit is cleared by a read access to this register.                                                                                                                                                                                                                                                                                                                                                                |
| Bit 4: 3   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 2      | ERWF     | 0x0         | rw   | Enable Remote Wakeup Frame<br>When this bit is set, it indicates that the power management event is generated due to a remote wakeup frame reception.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 1      | EMP      | 0x0         | rw   | Enable Magic Packet<br>When this bit is set, it indicates that the power management event is generated due to a Magic packet reception.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 0      | PD       | 0x0         | rw1s | Power Down<br>When this bit is set, the MAC receiver will drop all received frames after receiving the expected Magic packet or a remote wakeup frame. Then this bit is automatically cleared and power-down mode is disabled. This bit can also be cleared by software before the expected Magic packet or a remote wakeup frame is received. After this bit is cleared, the MAC forwards the receive frames to the application. This bit must only be set when either the Magic Packet enable bit, global unicast bit or the remote wakeup frame enable bit is set high. |

### 26.3.11 Ethernet MAC interrupt status register (EMAC\_MACISTS)

The Ethernet MAC interrupt status register identify the events in the MAC that can generate an interrupt.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                      |
| Bit 9      | TIS      | 0x0         | rrc  | Timestamp Interrupt Status<br>When this bit is set, it indicates that the system time value equals or exceeds the value programmed in the destination time registers. This bit is cleared after the completion of a read operation to this bit. |
| Bit 8: 7   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                      |
| Bit 6      | MTIS     | 0x0         | ro   | MMC Transmit Interrupt Status<br>This bit is set when an interrupt event is generated in the EMAC_MMCTI register. This bit is cleared when all bits in the transmit interrupt register are cleared.                                             |
| Bit 5      | MRIS     | 0x0         | ro   | MMC Receive Interrupt Status<br>This bit is set when an interrupt is generated in the                                                                                                                                                           |

|          |          |     |      |                                                                                                                                                                                                                                                                                           |
|----------|----------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | EMAC_MMCR1 register. This bit is cleared when all bits in the receive interrupt register are cleared.                                                                                                                                                                                     |
| Bit 4    | MIS      | 0x0 | ro   | MMC Interrupt Status<br>This bit is set whenever any bit of the [7: 5] bit is set high.<br>This bit is cleared only when these bits are set low.                                                                                                                                          |
| Bit 3    | PIS      | 0x0 | ro   | PMT Interrupt Status<br>This bit is set when a Magic packet or a remote wakeup event is received in power-down mode (see bits 5 and 6 in the EMAC_MACPMTCTRLSTS register). This bit is cleared when both bits [6: 5] are cleared due to a read access to the EMAC_MACPMTCTRLSTS register. |
| Bit 2: 0 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                |

### 26.3.12 Ethernet MAC interrupt mask register (EMAC\_MAIMR)

The Ethernet MAC interrupt mask register is used to mask the interrupt signal generated due to the corresponding event in the EMAC\_MACISTS register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                              |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15: 10 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                               |
| Bit 9      | TIM      | 0x0         | rw   | Timestamp Interrupt Mask<br>When this bit is set, it masks the interrupt signal generated in the time stamp interrupt status bit of the EMAC_MACISTS register. This bit is applicable only when the IEEE1588 time stamp is enabled. This bit is reserved in other modes. |
| Bit 8: 4   | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                               |
| Bit 3      | PIM      | 0x0         | rw   | PMT Interrupt Mask.<br>When this bit is set, it masks the interrupt signal generated in the MPT interrupt status bit of the EMAC_MACISTS register.                                                                                                                       |
| Bit 2: 0   | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                               |

### 26.3.13 Ethernet MAC address 0 high register (EMAC\_MACA0H)

The EMAC\_MACA0H register contains the upper 6 bits of the first 6-byte MAC address of the station. The first DA byte received on the MII interface corresponds to the LS byte (bit [7: 0]) of the MAC address low register. For example, if the 0x112233445566 (0x11 in channel 0 of the first column) is received on the MII interface as the destination address, then the MacAddress0 register [47: 0] is compared with 0x665544332211.

If the MAC address register is configured to be double-synchronized with the MII domain, the synchronization can be enabled only by writing the bit [31: 24] (in little endian mode) or the bit [7: 0] (in big-endian mode) in the Ethernet MAC address 0 low register (EMAC\_MACA0L). Consecutive write operations to this address low register must be performed after at least 4 cycles in the destination clock domain so as to achieve an accurate synchronous update.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                           |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | AE       | 0x0         | rrc  | Address<br>Always 1.                                                                                                                                                                                                                  |
| Bit 30: 16 | Reserved | 0x0010      | resd | Kept at its default value.                                                                                                                                                                                                            |
| Bit 15: 0  | MA0H     | 0xFFFF      | rw   | MAC Address0 [47: 32]<br>This field contains the upper 16 bits of the first 6-byte MCU address. This is used by the MAC for filtering received frames, and for inserting the MAC address in the transmit flow control frames (Pause). |

### 26.3.14 Ethernet MAC address 0 low register (EMAC\_MACA0L)

The Ethernet MAC address 0 low register contains the lower 32 bits of the 6-byte first MAC address.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                          |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | MA0L | 0xFFFF FFFF | rw   | MAC Address0 [31: 0]<br>This field contains the lower 16 bits of the first 6-byte MCU address. This is used by the MAC for filtering received frames, and for inserting the MAC address in the transmit flow control frames (Pause). |

### 26.3.15 Ethernet MAC address 1 high register (EMAC\_MACA1H)

The Ethernet MAC address 1 high register holds the upper 16 bits of the 6-byte second MAC address.

If the MAC address register is configured to be double-synchronized with the MII domain, the synchronization can be enabled only by writing the bit [31: 24] (in little endian mode) or the bit [7: 0] (in big-endian mode) in the Ethernet MAC address 1 low register (EMAC\_MACA1L). Consecutive write operations to this address low register must be performed after at least 4 cycles in the destination clock domain so as to achieve an accurate synchronous update.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | AE       | 0x0         | rw   | Address Enable<br>When this bit is set, the address filter uses the second MAC address for a perfect filtering.<br>When this bit is cleared, the address filter will ignore the address for filtering.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 30     | SA       | 0x0         | rw   | Source Address<br>When this bit is set, the MAC address 1 [47: 0] is used for comparison with the source address field of the received frame.<br>When this bit is cleared, the MAC address 1 [47: 0] is used for comparison with the destination address field of the received frame.                                                                                                                                                                                                                                                                                                           |
| Bit 29: 24 | MBC      | 0x00        | rw   | Mask Byte Control<br>These bits are mask control bits for comparison with each of the MAC address bytes.<br>When this bit is set, the MAC does not compare the corresponding byte of the received DA/SA with the contents of the MAC address 1 register. Each control bit is used for controlling the mask of the bytes as follows:<br>Bit 29: EMAC_MACA1H [15: 8]<br>Bit 28: EMAC_MACA1H [7: 0]<br>Bit 27: EMAC_MACA1L[31: 24]<br>...<br>Bit 24: EMAC_MACA1L[7: 0]<br>It is possible to filter group addresses (that is, group address filtering) by masking one or more bytes of the address. |
| Bit 23: 16 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 15: 0  | MA1H     | 0xFFFF      | rw   | MAC Address1 [47: 32]<br>These bits contain the upper 16 bits (47: 32) of the 6-byte second MAC address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 26.3.16 Ethernet MAC address 1 low register (EMAC\_MACA1L)

The Ethernet MAC address 1 low register contains the lower 32 bits of the 6-byte second MAC address.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                              |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | MA1L | 0xFFFF FFFF | rw   | MAC Address1 [31: 0]<br>These bits contain the lower 32 bits of the 6-byte second MAC address. The contents of this field is undefined until loaded by the application after the initialization process. |

### 26.3.17 Ethernet MAC address 2 high register (EMAC\_MACA2H)

The Ethernet MAC address 2 high register holds the upper 16 bits of the 6-byte second MAC address. If the MAC address register is configured to be double-synchronized with the MII domain, the synchronization can be enabled only by writing the bit [31: 24] (in little endian mode) or the bit [7: 0] (in big-endian mode) in the Ethernet MAC address 2 low register (EMAC\_MACA2L). Consecutive write operations to this address low register must be performed after at least 4 cycles in the destination clock domain so as to achieve an accurate synchronous update.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31     | AE       | 0x0         | rw   | Address Enable<br>When this bit is set, the address filter uses the second MAC address for a perfect filtering.<br>When this bit is cleared, the address filter will ignore the address for filtering.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 30     | SA       | 0x0         | rw   | Source Address<br>When this bit is set, the MAC address2 [47: 0] is used for comparison with the source address field of the received frame.<br>When this bit is cleared, the MAC address 2 [47: 0] is used for comparison with the destination address field of the received frame.                                                                                                                                                                                                                                                                                                            |
| Bit 29: 24 | MBC      | 0x00        | rw   | Mask Byte Control<br>These bits are mask control bits for comparison with each of the MAC address bytes.<br>When this bit is set, the MAC does not compare the corresponding byte of the received DA/SA with the contents of the MAC address 2 register. Each control bit is used for controlling the mask of the bytes as follows:<br>Bit 29: EMAC_MACA2H [15: 8]<br>Bit 28: EMAC_MACA2H [7: 0]<br>Bit 27: EMAC_MACA2L[31: 24]<br>...<br>Bit 24: EMAC_MACA2L[7: 0]<br>It is possible to filter group addresses (that is, group address filtering) by masking one or more bytes of the address. |
| Bit 23: 16 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 15: 0  | MA2H     | 0xFFFF      | rw   | MAC Address2 High [47: 32]<br>These bits contain the upper 16 bits (47: 32) of the 6-byte second MAC address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 26.3.18 Ethernet MAC address 2 low register (EMAC\_MACA2L)

The Ethernet MAC address 2 low register holds the lower 32 bits of the 6-byte second MAC address.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                  |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | MA2L | 0xFFFF FFFF | rw   | MAC Address2 Low [31: 0]<br>These bits contain the lower 32 bits of the 6-byte second MAC address. The contents of this field is undefined until loaded by the application after the initialization process. |

### 26.3.19 Ethernet MAC address 3 high register (EMAC\_MACA3H)

The Ethernet MAC address 3 high register holds the upper 16 bits of the 6-byte second MAC address. If the MAC address register is configured to be double-synchronized with the MII domain, the synchronization can be enabled only by writing the bit [31: 24] (in little endian mode) or the bit [7: 0] (in big-endian mode) in the Ethernet MAC address 3 low register (EMAC\_MACA3L). Consecutive write operations to this address low register must be performed after at least 4 cycles in the destination clock domain so as to achieve an accurate synchronous update.

| Bit    | Name | Reset value | Type | Description                                                                                                     |
|--------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------|
| Bit 31 | AE   | 0x0         | rw   | Address Enable<br>When this bit is set, the address filter uses the second MAC address for a perfect filtering. |

|            |          |        |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|----------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |        |      | When this bit is cleared, the address filter will ignore the address for filtering.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 30     | SA       | 0x0    | rw   | <p>Source Address</p> <p>When this bit is set, the MAC address 3 [47: 0] is used for comparison with the source address field of the received frame.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            |          |        |      | <p>When this bit is cleared, the MAC address 3 [47: 0] is used for comparison with the destination address field of the received frame.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 29: 24 | MBC      | 0x00   | rw   | <p>Mask Byte Control</p> <p>These bits are mask control bits for comparison with each of the MAC address bytes.</p> <p>When this bit is set, the MAC does not compare the corresponding byte of the received DA/SA with the contents of the MAC address 3 register. Each control bit is used for controlling the mask of the bytes as follows:</p> <ul style="list-style-type: none"> <li>Bit 29: EMAC_MACA3H [15: 8]</li> <li>Bit 28: EMAC_MACA3H [7: 0]</li> <li>Bit 27: EMAC_MACA3L[31: 24]</li> <li>...</li> <li>Bit 24: EMAC_MACA3L[7: 0]</li> </ul> <p>It is possible to filter group addresses (that is, group address filtering) by masking one or more bytes of the address.</p> |
| Bit 23: 16 | Reserved | 0x00   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 15: 0  | MA3H     | 0xFFFF | rw   | <p>MAC Address3 High [47: 32]</p> <p>These bits contain the lower 16 bits (47: 32) of the 6-byte second MAC address.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 26.3.20 Ethernet MAC address 3 low register (EMAC\_MACA3L)

The Ethernet MAC address 3 low register holds the lower 32 bits of the 6-byte second MAC address.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                             |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | MA3L | 0xFFFF FFFF | rw   | <p>MAC Address3 Low [31: 0]</p> <p>These bits contain the lower 32 bits of the 6-byte second MAC address. The contents of this field is undefined until loaded by the application after the initialization process.</p> |

### 26.3.21 Ethernet DMA bus mode register (EMAC\_DMABM)

The Ethernet DMA bus mode register defines the bus operation modes for the DMA.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 26 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 25     | AAB      | 0x0         | rw   | <p>Address-Aligned Beats</p> <p>When this bit is set and the FB bit equals 1, the AHB interface generates burst transfers aligned to the start address LS bits. If the FB bit equals 0, the first burst transfer (accessing the data buffer's start address) is not aligned, but subsequent burst transfers are aligned to the address.</p> <p>This bit is applicable to GMAC-AHB and GMAC-AXI configurations only. It is reserved in other configurations.</p> |
| Bit 24     | PBLx8    | 0x0         | rw   | <p>PBLx8 Mode</p> <p>When this bit is set, this bit multiples the PBL value programmed (bits [22: 17] and bits [13: 8] ) by 8. Thus the DMA transfers data at 8, 16, 32, 64, 128 and 256 beats depending on the PBL value.</p>                                                                                                                                                                                                                                  |
| Bit 23     | USP      | 0x0         | rw   | <p>Use separate PBL</p> <p>When this bit is set, the Rx DMA uses the value programmed in bit [22: 17] as PBL. The PBL value in bit [13: 8] is applicable to Tx DMA operations only.</p> <p>When this bit is cleared, the PBL value in bit [13: 8] is applicable to both Tx DMA and Rx DMA operations.</p>                                                                                                                                                       |
| Bit 22: 17 | RDP      | 0x01        | rw   | Rx DMA PBL                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|            |     |      |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-----|------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |     |      |    | This field indicates the maximum number of beats to be transferred in one Rx DMA operation. This is the maximum value that is used for a single write or read operation.<br>The Rx DMA always attempts to perform burst transfer as specified in RPBL each time it starts a burst transfer on the host bus. The RPBL can be programmed with 1, 2, 4, 8, 16 and 32. Any other value result in unexpected behavior. These bits are applicable only when the USP bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 16     | FB  | 0x0  | rw | Fixed Burst<br>This bit controls whether the AHB master interface performs fixed burst transfers or not. When this bit is set, the AHB uses only SINGLE, INCR4, INCR8 or INCR16 during start of normal burst transfers. When this bit is cleared, the AHB or AXI interface uses SINGLE and INCR burst transfer operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 15: 14 | PR  | 0x0  | rw | Priority Ratio<br>These bits control the priority ratio of the round-robin arbitration between Rx DMA and Tx DMA. These bits are valid only when the bit 1 (destination address) is reset. The priority ratio is either Rx: Tx or Tx: Rx, depending on whether the bit 27 (TXPR) is set or reset.<br>00: 1: 1<br>01: 2: 1<br>10: 3: 1<br>11: 4: 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 13: 8  | PBL | 0x01 | rw | Programmable Burst Length<br>These bits indicate the maximum number of beats to be transferred in one DMA transaction. This is the maximum that is used for a single write or read operation.<br>The DMA always attempts to perform burst transfer as specified in PBL each time it starts a burst transfer on the host bus. The RPBL can be programmed with 1, 2, 4, 8, 16 and 32. Any other value result in unexpected behavior. When the USP is set, the PBL value is applicable to Tx DMA operations only.<br>If the number of beats to be transferred is greater than 32, the following steps are required:<br>1. Set PBLx8 mode<br>2. Set PBL<br>For example, if the maximum value to be transferred is greater than 64, then the PBLx8 should be set first, and then the PBL is set to 8. The PBL values have the following limitations:<br>The maximum number of beats possible is limited by the size of the Tx FIFO and Rx FIFO on the MTL layer, as well as the data bus width on the DMA.<br>FIFO constraint: The maximum beat supported by the FIFO is half the depth of the FIFO, unless otherwise specified. |
| Bit 7      | EDE | 0x0  | rw | Enhanced descriptor enable<br>When this bit is set to 1, the enhanced descriptor format is enabled and the descriptor size is increased to 8 words. For details, refer to TX enhanced descriptors and RX enhanced descriptors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 6: 2   | DSL | 0x00 | rw | Descriptor Skip Length<br>These bits define the number of words to skip between two unchained descriptors. The address skip starts from the end of the current descriptor to the start of next descriptor. When the DSL value equals 0, the descriptor is regarded as contiguous by the DMA in ring mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 1      | DA  | 0x0  | rw | DMA Arbitration<br>These bits specify the arbitration scheme between the transmit path and receive path of channel 0.<br>0: Rx: Tx or Tx: Rx<br>The priority between round-robin channels depends on the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|       |     |     |    |                                                                                                                                                                                                                          |
|-------|-----|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     |    | priority as specified in the bit [15: 14] (PR) and the priority weight as specified in bit 27(TXPR).<br>1: Fixed priority<br>When the bit 27 (TXPR) is set, Tx has priority over Rx. Otherwise, Rx has priority over Tx. |
| Bit 0 | SWR | 0x1 | rw | Software Reset<br>When this bit is set, the MAC DMA controller resets all internal registers and MAC logic. This bit is automatically cleared after all reset operations have been completed.                            |

### 26.3.22 Ethernet DMA transmit poll demand register (EMAC\_DMATPD)

The EMAC\_DMATPD register enables the Tx DMA to check whether or not the current descriptor is owned by the DMA. The Transmit Poll Demand is used to wake up the Tx DMA from suspend mode. The Tx DMA can go into suspend mode due to an underflow error in a transmitted frame or due to the unavailability of descriptors owned by transmit DMA. The Poll demand can be issued at any time, and the Tx DMA will reset this command once it starts re-fetching the current descriptor from the host memory. This register is always read 0.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                        |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TPD  | 0x0000 0000 | rrc  | Transmit Poll Demand<br>When these bits are written with any value, the DMA reads the current descriptor pointed to by the EMAC_DMACTD. If the descriptor is not available (owned by host), the transmission suspends, and the bit 2 (TU) is set in the status register. If the descriptor is available, the transmission resumes. |

### 26.3.23 Ethernet DMA receive poll demand register (EMAC\_DMARPD)

The EMAC\_DMARPD register enables the Rx DMA to check new descriptors. The Receive Poll Demand is used to wake up the Rx DMA from suspend mode. The Rx DMA can enter suspend mode due to the unavailability of descriptors owned by it.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                |
|-----------|------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | RPD  | 0x0000 0000 | rrc  | Receive Poll Demand<br>When these bits are written with any value, the DMA reads the current descriptor pointed to by the EMAC_DMARD. If the descriptor is not available (owned by host), the reception suspends, and the bit 7 (RU) is set in the status register. If the descriptor is available, the reception resumes. |

### 26.3.24 Ethernet DMA receive descriptor list address register (EMAC\_DMARDLADDR)

The EMAC\_DMARDLADDR register points to the start of the receive descriptor list. The descriptor list is located in the host's physical memory and must be word-aligned. The DMA enables bus-width aligned address by making the corresponding LS bit low. Writing to the register is permitted only when the Rx DMA stops. After the Rx DMA stops, this register must be written before the receive start command is given.

Writing to the register is permitted only when the Rx DMA stops. In other words, the bit 1 (SR) is set 0 in the operation mode register. After the Rx DMA stops, this register can be written with a new descriptor list address.

When the SR bit is set, the DMA uses the newly programmed descriptor base address.

If the SR is cleared and this register remains unchanged, then the DMA will use the previous descriptor address when the Rx DMA stops.

| Bit       | Name | Reset value | Type | Description           |
|-----------|------|-------------|------|-----------------------|
| Bit 31: 0 | SRL  | 0x0000 0000 | rw   | Start of Receive List |

These bits contain the base address of the first descriptor in the receive descriptor list. The LSB bits (1: 0, 2: 0 or 3: 0) for 32/64/128-bit bus width are ignored and taken as zero by the DMA. Therefore these LSB bits are read only.

### 26.3.25 Ethernet DMA transmit descriptor list address register (EMAC\_DMATDLADDR)

The EMAC\_DMATDLADDR register points to the start of the transmit descriptor list. The descriptor list is located in the host's physical memory and must be word-aligned. The DMA enables bus-width aligned address by making the corresponding LS bit low.

Writing to the register is permitted only when the Tx DMA stops. In other words, the bit 13 (ST) is set 0 in the register 6 (operation mode register). After the Tx DMA stops, this register can be written with a new descriptor list address.

When the SR bit is set, the DMA uses the newly programmed descriptor base address.

If the SR is cleared and this register remains unchanged, then the DMA will use the previous descriptor address when the Tx DMA stops.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                            |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | STL  | 0x0000 0000 | rw   | Start of Transmit List<br>These bits contain the base address of the first descriptor in the transmit descriptor list. The LSB bits (1: 0, 2: 0 or 3: 0) for 32/64/128-bit bus width are ignored and taken as zero by the DMA. Therefore these LSB bits are read only. |
|           |      |             |      |                                                                                                                                                                                                                                                                        |

### 26.3.26 Ethernet DMA status register (EMAC\_DMASTS)

The EMAC\_DMASTS register contains all the status bits the DMA reports to the host. This register is read by the software driver during an interrupt service routine or polling. Most of the bits in this register can trigger the host to be interrupted. The bits in this register cannot be cleared when read. Writing 1'b1 to the bit [16: 0] (unreserved) in this register clears them. Writing 1'b0 has no effect. Each bit (bit [16: 0]) can be masked through the corresponding bit in the interrupt enable mask register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                       |
| Bit 29     | TTI      | 0x0         | ro   | Timestamp Trigger Interrupt<br>This bit indicates an interrupt event in the time stamp generator block. The software must read the corresponding register to get interrupt sources.<br>This bit is applicable only when the IEEE1588 time stamp feature is enabled. Otherwise, this bit is reserved.                                             |
| Bit 28     | MPI      | 0x0         | ro   | MAC PMT Interrupt<br>This bit indicates an interrupt even in the PMT. The software must read the Ethernet PMT control and status register (EMAC_MACPMTCTRLSTS) to get the interrupt sources and clear them in order to reset this bit to 1'b0.<br>This bit is applicable only when the PMT function is enabled. Otherwise, this bit is reserved. |
| Bit 27     | MMI      | 0x0         | ro   | MAC MMC Interrupt<br>This bit indicates an interrupt event in the MMC. The software must read the corresponding register to get interrupt sources and clear them in order to reset this bit to 1'b0.<br>This bit is applicable only when the MAC MMC is enabled. Otherwise, this bit is reserved.                                                |
| Bit 26     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                       |
| Bit 25: 23 | EB       | 0x0         | ro   | Error Bits<br>These bits indicate the type of error that caused a bus error. They are applicable only when the bit 13 (FBI) is set.<br>This field does not generate an interrupt.<br>000: Error during data transfer by Rx DMA<br>011: Error during read transfer by Tx DMA<br>100: Error during Rx DMA descriptor write access                  |

|            |      |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |      |     |      | 101: Error during Tx DMA descriptor write access<br>110: Error during Rx DMA descriptor read access<br>111: Error during Tx DMA descriptor read access<br>Note: 001 and 010 are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 22: 20 | TS   | 0x0 | ro   | Transmit Process State<br>This field indicates the Tx DMA FSM state. This field does not generate an interrupt.<br>3'b000: Stopped; Rest or Stop transmit command issued<br>3'b001: Running; Fetching transmit descriptor<br>3'b010: Running; Waiting for status<br>3'b011: Running; Reading data from host memory buffer and queuing it to Tx FIFO<br>3'b100: Time stamp write status<br>3'b101: Reserved for future use<br>3'b110: Suspended; Transmit descriptor unavailable or transmit buffer underflow<br>3'b111: Running; Closing transmit descriptor                                                                                                                                                                                                                                        |
| Bit 19: 17 | RS   | 0x0 | ro   | Receive Process State<br>This field indicates the Rx DMA FSM state. This field does not generate an interrupt.<br>3'b000: Stopped; Rest or Stop transmit command issued<br>3'b001: Running; Fetching receive descriptor<br>3'b010: Reserved for future use<br>3'b011: Running; Waiting for receive packet<br>3'b100: Suspended; Receive descriptor unavailable<br>3'b101: Running; Closing receive descriptor<br>3'b110: Time stamp write status<br>3'b111: Running; Transferring the receive buffer data to host memory                                                                                                                                                                                                                                                                            |
| Bit 16     | NIS  | 0x0 | rw1c | Normal Interrupt Summary<br>The normal interrupt summary value is the logic OR of the following bits when the corresponding interrupt bits are enabled in the interrupt enable registers.<br>EMAC_DMASTS[0]: Transmit interrupt<br>EMAC_DMASTS[2]: Transmit buffer unavailable<br>EMAC_DMASTS[6]: Receive interrupt<br>EMAC_DMASTS[14]: Early receive interrupt<br>Only unmasked bits affect the normal interrupt summary. This is a sticky bit and it must be cleared (by writing 1 to this bit) each time a corresponding bit (causes NIS to be set) is cleared.                                                                                                                                                                                                                                  |
| Bit 15     | AIS  | 0x0 | rw1c | Abnormal Interrupt Summary<br>The abnormal interrupt summary value is the logic OR of the following bits when the corresponding interrupt bits are enabled in the interrupt enable registers.<br>EMAC_DMASTS[1]: Transmit process stopped<br>EMAC_DMASTS[3]: Transmit Jabber timeout<br>EMAC_DMASTS[4]: Receive FIFO overflow<br>EMAC_DMASTS[5]: Transmit data underflow<br>EMAC_DMASTS[7]: Receive buffer unavailable<br>EMAC_DMASTS[8]: Receive process stopped<br>EMAC_DMASTS[9]: Receive watchdog timeout<br>EMAC_DMASTS[10]: Early transmit interrupt<br>EMAC_DMASTS[13]: Fatal bus error<br>Only unmasked bits affect the abnormal interrupt summary. This is a sticky bit and it must be cleared (by writing 1 to this bit) each time a corresponding bit (causes AIS to be set) is cleared. |
| Bit 14     | ERI  | 0x0 | rw1c | Early Receive Interrupt<br>This bit indicates that the DMA has filled the first data buffer of the packet. This bit is cleared when the software writes 1 to this bit or when the bit 6 (RI) bit is set in this register. (Whichever occurs first)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 13     | FBEI | 0x0 | rw1c | Fatal Bus Error Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |     |      | This bit indicates that a bus error occurred as defined in bit [25: 23]. When this bit is set, the corresponding DMA will disable all its bus accesses.                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 12: 11 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 10     | ETI      | 0x0 | rw1c | Early Transmit Interrupt<br>This bit indicates that the frame to be transmitted was fully sent to the MTL Tx FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 9      | RWT      | 0x0 | rw1c | Receive Watchdog Timeout<br>When this bit is set, it indicates that the receive watchdog timer timeout occurs while receiving the current frame, and the current frame is cut off after the watchdog timeout happens.                                                                                                                                                                                                                                                                                                                      |
| Bit 8      | RPS      | 0x0 | rw1c | Receive Process Stopped<br>This bit is set when the receive process enters the stop state.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 7      | RBU      | 0x0 | rw1c | Receive Buffer Unavailable<br>This bit indicates that the next descriptor in the receive list is owned by the host and cannot be acquired by the DMA. Thus the receive process is suspended. The host should change the ownership of the descriptor and release the receive poll demand command in order to resume receive process. If no receive poll demand command is issued, the receive process resumes when the DMA receives the next incoming frame. This bit is set only when the previous receive descriptor is owned by the DMA. |
| Bit 6      | RI       | 0x0 | rw1c | Receive Interrupt<br>This bit indicates the completion of a frame reception. After the completion of a frame reception, the bit 31 of the RDES1 (interrupt disabled after reset operation) is reset in the last descriptor. Specific frame status information will be posted in the descriptor. Receive process remains in the running state.                                                                                                                                                                                              |
| Bit 5      | UNF      | 0x0 | rw1c | Transmit Underflow<br>This bit indicates that the transmit buffer has an underflow during a frame transmission. Transmit process is suspended and the underflow error bit TDES0[1] is set.                                                                                                                                                                                                                                                                                                                                                 |
| Bit 4      | OVF      | 0x0 | rw1c | Receive Overflow<br>This bit indicates that the receive buffer has an overflow during a frame reception. If the partial frame has been transferred to the application, the overflow status is set in the RDES0[11].                                                                                                                                                                                                                                                                                                                        |
| Bit 3      | TJT      | 0x0 | rw1c | Transmit Jabber Timeout<br>This bit indicates that the transmit Jabber timer will expire when the current frame is greater than 2048 bytes (it is 10240 bytes if Jumbo frame is enabled). After the Jabber is expired, the transmit process is aborted and enters stop state, which causes the transmit Jabber timeout flag bit TDES0[14] to be set.                                                                                                                                                                                       |
| Bit 2      | TBU      | 0x0 | rw1c | Transmit Buffer Unavailable<br>This bit indicates that the next descriptor in the transmit list is owned by the host and cannot be acquired by the DMA. Then the transmit process is suspended. Bit [22: 20] explains the transmit process state. To resume transmit process, the host should change the ownership of the descriptor by setting the TDES0[31] and issue the transmit poll demand command                                                                                                                                   |
| Bit 1      | TPS      | 0x0 | rw1c | Transmit Process Stopped<br>This bit is set when the transmit process stops.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 0      | TI       | 0x0 | rw1c | Transmit Interrupt<br>This bit indicates the completion of a frame transmission. The bit 31 (OWN) is reset in the TDES0. Specific frame status information will be posted in the descriptor.                                                                                                                                                                                                                                                                                                                                               |

### 26.3.27 Ethernet DMA operation mode register (EMAC\_DMAOPM)

The EMAC\_DMAOPM register defines the receive and transmit operation modes and commands. This register should be the last CSR to be written during DMA initialization. This register is also applicable to GMAC-MTL configuration where the unused and reserved bits are 24, 13, 2 and 1. A delay value greater than 4us is required between two consecutive write accesses to this register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 27 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 26     | DT       | 0x0         | rw   | Disable Dropping of TCP/IP Checksum Error Frames<br>When this bit is set, the MAC does not drop the frames that only have errors detected by the receive checksum offload engine. Such frames have errors in the encapsulated payload only but do not have errors (including FCS error) in the Ethernet frames received by the MAC. When this bit is cleared, all error frames are dropped if the FEF bit is reset.                                                                                                                                                                                                        |
| Bit 25     | RSF      | 0x0         | rw   | Receive Store and Forward<br>When this bit is set, the MTL reads the Rx FIFO only after a full frame is written to the Rx FIFO, ignoring the RTC bit. When this bit is cleared, the Rx FIFO operates in cut-through mode and will be subject to the threshold defined by the RTC.                                                                                                                                                                                                                                                                                                                                          |
| Bit 24     | DFRF     | 0x0         | rw   | Disable Flushing of Received Frames<br>When this bit is set, the Rx DMA does not flush any receive frame due to the unavailability of receive descriptors or receive buffers. When this bit is cleared, the DMA will flush receive frames in case of the above-mentioned circumstances.                                                                                                                                                                                                                                                                                                                                    |
| Bit 23: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 21     | TSF      | 0x0         | rw   | Transmit Store and Forward<br>When this bit is set, transmission starts when a full frame resides in the Tx FIFO, and the TTC values specified in the bit [16: 14] are ignored. This bit can be changed only when the transmit process stops.                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 20     | FTF      | 0x0         | rw   | Flush Transmit FIFO<br>When this bit is set, the Tx FIFO controller logic is reset of its default values and thus all data in the Tx FIFO are either lost or flushed. This bit is cleared after the completion of the flushing operation. The operation mode register should not be written before this bit is cleared. The data that has been received by the MAC transmitter is not flushed and is going to be transferred, causing data underflow and runt frame transfer (If you want to change this bit through consecutive commands, a delay value greater than 4us is required between two consecutive operations.) |
| Bit 19: 17 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 16: 14 | TTC      | 0x0         | rw   | Transmit Threshold Control<br>These bits control the threshold of the Tx FIFO. Transmission starts when the frame size in the Tx FIFO is greater than the threshold. In addition, full frames with a length less than the threshold are also transmitted. These bits are applicable only when the bit 21 (TSF) is reset.<br>000: 64<br>001: 128<br>010: 192<br>011: 256<br>100: 40<br>101: 32<br>110: 24<br>111: 16                                                                                                                                                                                                        |
| Bit 13     | SSTC     | 0x0         | rw   | Start or Stop Transmission Command<br>When this bit is set, transmission is in the running state, and the DMA checks the transmit list at the current location                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

and determines the frame to be transmitted. The DMA acquires the descriptor either from the current position in the list (the transmit list base address set by the transmit descriptor list address register) or from the position where the transmit process was stopped previously. If the current descriptor is owned by the DMA, the transmit process enters suspend state, and the bit 2 (transmit buffer unavailable) is set in the status register. Transmission command is valid only when the transmission is stopped. If the transmit command were issued before setting the transmit descriptor list address register, the DMA will show unpredictable behavior.

When this bit is cleared, transmit process enters stop state after the completion of a frame transmission. The next descriptor position in the transmit list is saved, and becomes the current position when transmission gets started. To change the list address, write a new value to the transmit descriptor list address register when this bit is reset. The newly written value becomes effective only when this bit is set again. The Stop Transmission Command is effective only when the current frame transmission is complete or transmit process enters suspend state.

|           |          |      |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|----------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 12: 8 | Reserved | 0x00 | resd | Kept at its default value.<br><br>Forward Error Frames<br>1: All frames except runt error frames are forwarded to the DMA<br>0: Rx FIFO drops error frames (CRC error, collision error, giant frame, watchdog timeout and overflow). However, if the frame's start byte point has already been transferred to the application in Threshold mode, then the frames are not dropped. The Rx FIFO drops the error frames whose start bytes have not been transferred to the AHB bus.                               |
| Bit 7     | FEF      | 0x0  | rw   | Forward Undersized Good Frames<br>When this bit is set, the Rx FIFO forwards undersized good frames including pad bytes and CRC (with no error and length less than 64 bytes).<br>When this bit is cleared, the Rx FIFO drops all frames with a length less than 64 bytes, unless such a frame has already been transferred to the application due to a lower value than the receive threshold (e.g. RTC=01).                                                                                                  |
| Bit 6     | FUGF     | 0x0  | rw   | Receive Threshold Control<br>These two bits control the threshold of the Rx FIFO. Transfer to DMA starts when the frame in the Rx FIFO is larger than the threshold. In addition, full frames with a length less than the threshold are also automatically transferred.<br>Value 11 is not applicable if the Rx FIFO size is configured to be 128 bytes.<br>These bits are applicable only when the RSF bit equals 0. These bits are ignored when the RSF bit is set.<br>00: 64<br>01: 32<br>10: 96<br>11: 128 |
| Bit 4: 3  | RTC      | 0x0  | rw   | Operate on Second Frame<br>When this bit is set, it instructs the DMA to process a second frame of transmit data even before the status of the first frame is obtained.                                                                                                                                                                                                                                                                                                                                        |
| Bit 2     | OSF      | 0x0  | rw   | Start or Stop Receive<br>When this bit is set, the receive process is in the running state, and the DMA attempts to acquire the descriptor from the receive list and processes incoming frames. The DMA acquires the descriptor either from the current position in                                                                                                                                                                                                                                            |

the list (the receive list base address set by the receive descriptor list address register) or from the position where the receive process was stopped previously. If the current descriptor is owned by the DMA, the receive process enters suspend state, and the bit 7 (receive buffer unavailable) is set in the status register. Reception command is valid only when the reception is stopped. If the reception command were issued before setting the receive descriptor list address register, the DMA will show unpredictable behavior.

When this bit is cleared, Rx DMA operation is stopped after the completion of a frame reception. The next descriptor position in the receive list is saved, and becomes the current position when reception process is restarted. The Stop Rece[tpm] Command is effective only when the receive process enters in the running state (waiting for receive packet) or the suspend state.

|       |          |     |      |                            |
|-------|----------|-----|------|----------------------------|
| Bit 0 | Reserved | 0x0 | resd | Kept at its default value. |
|-------|----------|-----|------|----------------------------|

### 26.3.28 Ethernet DMA interrupt enable register (EMAC\_DMAIE)

The EMAC\_DMAIE register enables the interrupts reported by the status register. Setting a bit to 1'b1 enables a corresponding interrupt. All interrupts are disabled after a software or hardware reset.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 17 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 16     | NIE      | 0x0         | rw   | Normal Interrupt enable<br>When this bit is set, a normal interrupt summary is enabled. When this bit is cleared, a normal interrupt summary is disabled. This bit enables the following bits (in the status register)<br>EMAC_DMASTS[0]: Transmit interrupt<br>EMAC_DMASTS[2]: Transmit buffer unavailable<br>EMAC_DMASTS[6]: Receive interrupt<br>EMAC_DMASTS[14]: Early receive interrupt                                                                                                                                                                                                                                   |
| Bit 15     | AIE      | 0x0         | rw   | Abnormal interrupt enable<br>When this bit is set, an abnormal interrupt summary is enabled. When this bit is cleared, an abnormal interrupt summary is disabled. This bit enables the following bits (in the status register)<br>EMAC_DMASTS[1]: Transmit process stopped<br>EMAC_DMASTS[3]: Transmit Jabber timeout<br>EMAC_DMASTS[4]: Transmit overflow<br>EMAC_DMASTS[5]: Transmit data underflow<br>EMAC_DMASTS[7]: Transmit buffer u unavailable<br>EMAC_DMASTS[8]: Receive process stopped<br>EMAC_DMASTS[9]: Receive watchdog timeout<br>EMAC_DMASTS[10]: Early transmit interrupt<br>EMAC_DMASTS[13]: Fatal bus error |
| Bit 14     | ERE      | 0x0         | rw   | Early Receive interrupt Enable<br>When this bit is set with the normal interrupt summary enable bit, the early receive interrupt is enabled. When this bit is cleared, the early receive interrupt is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 13     | FBEE     | 0x0         | rw   | Fatal Bus Error Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the fatal bus error interrupt is enabled. When this bit is cleared, the fatal bus error enable interrupt is disabled.                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 12: 11 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 10     | EIE      | 0x0         | rw   | Early transmit Interrupt Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the early transmit interrupt is enabled. When this bit is cleared, the early transmit interrupt is disabled.                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 9      | RWTE     | 0x0         | rw   | Receive Watchdog Timeout Enable<br>When this bit is set with the abnormal interrupt summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|       |      |     |    |                                                                                                                                                                                                                                                 |
|-------|------|-----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |    | enable bit, the receive watchdog timeout interrupt is enabled. When this bit is cleared, the receive watchdog timeout interrupt is disabled.                                                                                                    |
| Bit 8 | RSE  | 0x0 | rw | Receive Stopped Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the receive stopped interrupt is enabled. When this bit is cleared, the receive stopped interrupt is disabled.                                   |
| Bit 7 | RBUE | 0x0 | rw | Receive Buffer Unavailable Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the receive buffer unavailable interrupt is enabled. When this bit is cleared, the receive buffer unavailable interrupt is disabled.  |
| Bit 6 | RIE  | 0x0 | rw | Receive Interrupt Enable<br>When this bit is set with the normal interrupt summary enable bit, the receive interrupt is enabled. When this bit is cleared, the receive interrupt is disabled.                                                   |
| Bit 5 | UNE  | 0x0 | rw | Underflow Interrupt Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the underflow interrupt is enabled. When this bit is cleared, the underflow interrupt is disabled.                                           |
| Bit 4 | OVE  | 0x0 | rw | Overflow Interrupt Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the overflow interrupt is enabled. When this bit is cleared, the overflow interrupt is disabled.                                              |
| Bit 3 | TJE  | 0x0 | rw | Transmit Jabber Timeout Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the transmit Jabber timeout interrupt is enabled. When this bit is cleared, the transmit Jabber timeout interrupt is disabled.           |
| Bit 2 | TUE  | 0x0 | rw | Transmit Buffer Unavailable Enable<br>When this bit is set with the normal interrupt summary enable bit, the transmit buffer unavailable interrupt is enabled. When this bit is cleared, the transmit buffer unavailable interrupt is disabled. |
| Bit 1 | TSE  | 0x0 | rw | Transmit Stopped Enable<br>When this bit is set with the abnormal interrupt summary enable bit, the transmit stopped interrupt is enabled. When this bit is cleared, the transmit stopped interrupt is disabled.                                |
| Bit 0 | TIE  | 0x0 | rw | Transmit Interrupt Enable<br>When this bit is set with the normal interrupt summary enable bit, the transmit interrupt is enabled. When this bit is cleared, the transmit interrupt is disabled.                                                |

The Ethernet interrupt is generated only when the TST or PMT bit is set in the DMA status register with other interrupts unmasked, or when the NIS/AIS is enabled with other interrupts enabled.

### 26.3.29 Ethernet DMA missed frame and buffer overflow counter register (EMAC\_DMAMFBOCNT)

The DMA contains two counters to track the number of missed frames during reception. This register reports the current value of the counter. The counter is used for the purpose of diagnosis. The bit [15: 0] indicates the number of missed frames due to the host buffer being unavailable. The bit [27: 17] indicate the number of missed frames due to buffer overflow (MTL and MAC) and runt frames dropped by the MTL.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 29 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                  |
| Bit 28     | OBFOC    | 0x0         | rrc  | Overflow Bit for FIFO Overflow Counter<br>This bit is set whenever an overflow occurs on the overflow frame counter ([27: 17]), that is, the Rx FIFO overflows, and the overflow frame counter reaches its maximum value. In this case, the overflow frame counter is reset to all zero, and this bit indicates that a toggle has occurred. |
| Bit 27: 17 | OFC      | 0x000       | rrc  | Overflow Frame Counter                                                                                                                                                                                                                                                                                                                      |

|           |       |        |     |                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       |        |     | These bits indicate the number of frames missed by the application.                                                                                                                                                                                                                                                                                                                            |
| Bit 16    | OBMFC | 0x0    | rrc | Overflow Bit for Missed Frame Counter<br>This bit is set whenever an overflow occurs on the missed frame counter ([15: 0]), that is, the DMA ignores incoming frames due to the host receive buffer being unavailable, and the missed frame counter reaches its maximum value. In this case, the missed frame counter is reset to all zero, and this bit indicates that a toggle has occurred. |
| Bit 15: 0 | MFC   | 0x0000 | rrc | Missed Frame Counter<br>This field indicates the number of frames missed by the controller due to the host receive buffer being unavailable. This counter is incremented each time the DMA discards an incoming frame.                                                                                                                                                                         |

### 26.3.30 Ethernet DMA current transmit descriptor register (EMAC\_DMACTD)

The EMAC\_DMACTD register points to the start address of the transmit descriptor being read by the DMA.

| Bit       | Name  | Reset value | Type | Description                                                                                                                  |
|-----------|-------|-------------|------|------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | HTDAP | 0x0000 0000 | ro   | Host Transmit Descriptor Address Pointer<br>These bits are cleared when reset. The DMA updates the pointer during operation. |

### 26.3.31 Ethernet DMA current receive descriptor register (EMAC\_DMARD)

The EMAC\_DMARD register points to the start address of the receive descriptor being read by the DMA.

| Bit       | Name  | Reset value | Type | Description                                                                                                                 |
|-----------|-------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | HRDAP | 0x0000 0000 | ro   | Host Receive Descriptor Address Pointer<br>These bits are cleared when reset. The DMA updates the pointer during operation. |

### 26.3.32 Ethernet DMA current transmit buffer address register (EMAC\_DMACTBADDR)

The EMAC\_DMACTBADDR register points to the transmit buffer address being read by the DMA.

| Bit       | Name  | Reset value | Type | Description                                                                                                              |
|-----------|-------|-------------|------|--------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | HTBAP | 0x0000 0000 | ro   | Host Transmit Buffer Address Pointer<br>These bits are cleared when reset. The DMA updates the pointer during operation. |

### 26.3.33 Ethernet DMA current receive buffer address register (EMAC\_DMARCBADDR)

The EMAC\_DMARCBADDR register points to the receive buffer address being read by the DMA.

| Bit       | Name  | Reset value | Type | Description                                                                                                             |
|-----------|-------|-------------|------|-------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | HRBAP | 0x0000 0000 | ro   | Host Receive Buffer Address Pointer<br>These bits are cleared when reset. The DMA updates the pointer during operation. |

### 26.3.34 Ethernet MMC control register (EMAC\_MMCTRL)

The EMAC\_MMCTRL register defines the operating mode of the management counters.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                  |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 4 | Reserved | 0x00000000  | resd | Kept at its default value.                                                                                                                   |
| Bit 3     | FMC      | 0x0         | rw   | Freeze MMC Counter<br>When this bit is set, it freezes all the MMC counters to their current value. None of the MMC counters are updated due |

|       |     |     |    |                                                                                                                                                                    |
|-------|-----|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     |    | to any transmitted or received frame until this bit is set to 0. If the Reset on Read bit is set while the MMC counter is being read, the counter is also cleared. |
| Bit 2 | RR  | 0x0 | rw | Reset on Read<br>When this bit is set, the MMC counter is reset to 0 after being read. The counter is cleared when the least significant byte bit [7: 0] is read.  |
| Bit 1 | SCR | 0x0 | rw | Stop Counter Rollover<br>When this bit is set, the counter does not roll over to 0 after it reaches the maximum value.                                             |
| Bit 0 | RC  | 0x0 | rw | Reset Counter<br>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.                                              |

### 26.3.35 Ethernet MMC receive interrupt register (EMAC\_MMCR1)

The EMAC\_MMCR1 register contains the interrupts generated in the following conditions:

- Receive statistic counters reaches half their maximum values (32-bit counter corresponds to 0x8000\_0000, and 16-bit counter corresponds to 0x8000)
- Receive statistic counters exceed their maximum values (32-bit counter corresponds to 0xFFFF\_FFFF, and 16-bit counter corresponds to 0xFFFF)

When the counter stops rolling, an interrupt is set but the counter is still all 1. The EMAC\_MMCR1 is a 32-bit register. An interrupt bit is cleared when the MMC counter that generates the interrupt is read. The least significant byte bit [7: 0] of the corresponding counter must be read in order to clear the interrupt bit.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 18 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                   |
| Bit 17     | RGUF     | 0x0         | rrc  | Received Good Unicast Frames<br>This bit is set when the received good unicast frame counter reaches the maximum value or half the maximum value.            |
| Bit 16: 7  | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                   |
| Bit 6      | RFAE     | 0x0         | rrc  | Received Frames Alignment Error<br>This bit is set when the received frame counter with alignment error reaches the maximum value or half the maximum value. |
| Bit 5      | RFCE     | 0x0         | rrc  | Received Frames CRC Error<br>This bit is set when the receive frame with CRC error reaches the maximum value or half the maximum value.                      |
| Bit 4: 0   | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                   |

### 26.3.36 Ethernet MMC transmit interrupt register (EMAC\_MMCTI)

The EMAC\_MMCTI register contains the interrupts generated in the following conditions: when the transmit statistic counters reach half their maximum values (32-bit counter corresponds to 0x8000\_0000, and 16-bit counter corresponds to 0x8000), and when the transmit statistic counters exceed their maximum values (32-bit counter corresponds to 0xFFFF\_FFFF, and 16-bit counter corresponds to 0xFFFF). When the counter stops rolling, an interrupt is set but the counter is still all 1. The EMAC\_MMCTI is a 32-bit register. An interrupt bit is cleared when the MMC counter that generates the interrupt is read. The least significant byte bit [7: 0] of the corresponding counter must be read in order to clear the interrupt bit.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                      |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                       |
| Bit 21     | TGF      | 0x0         | rrc  | Transmitted Good Frames<br>This bit is set when the transmitted good frame counter reaches its maximum value or half its maximum value.                                                          |
| Bit 20: 16 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                       |
| Bit 15     | TGFMSC   | 0x0         | rrc  | Transmitted Good Frames More Single Collision<br>This bit is set when the transmitted good frame after more than a single collision counter reaches its maximum value or half its maximum value. |

|           |          |        |      |                                                                                                                                                                                                    |
|-----------|----------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 14    | TSCGFCl  | 0x0    | rrc  | Transmitted Single Collision Good Frame Counter Interrupt<br>This bit is set when the transmitted good frame after a single collision counter reaches its maximum value or half its maximum value. |
| Bit 13: 0 | Reserved | 0x0000 | resd | Kept at its default value.                                                                                                                                                                         |

### 26.3.37 Ethernet MMC receive interrupt register (EMAC\_MMCRIM)

The EMAC\_MMCRIM contains the masks for interrupts generate when the receive statistic counters reach half their maximum values or their maximum values. This register is a 32-bit register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                  |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 18 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                   |
| Bit 17     | RUGFCIM  | 0x0         | rw   | Received Unicast Good Frame Counter Interrupt Mask<br>Setting this bit masks the interrupt when the received good unicast frame counter reaches half its maximum value or its maximum value.                 |
| Bit 16: 7  | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                   |
| Bit 6      | RAEFACIM | 0x0         | rw   | Received Alignment Error Frame Alignment Counter Interrupt Mask<br>Setting this bit masks the interrupt when the received alignment error frame counter reaches half its maximum value or its maximum value. |
| Bit 5      | RCEFCIM  | 0x0         | rw   | Received CRC Error Frame Counter Interrupt Mask<br>Setting this bit masks the interrupt when the received CRC error frame counter reaches half its maximum value or its maximum value.                       |
| Bit 4: 0   | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                   |

### 26.3.38 Ethernet MMC transmit interrupt register (EMAC\_MMCTIM)

The EMAC\_MMCTIM contains the masks for interrupts generate when the transmit statistic counters reach half their maximum values or their maximum values. This register is a 32-bit register.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                              |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 22 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                                                                               |
| Bit 21     | TGFCIM   | 0x0         | rw   | Transmitted Good Frame Counter Interrupt Mask<br>Setting this bit masks the interrupt when the transmitted good frame counter reaches half its maximum value or its maximum value.                                                       |
| Bit 20: 16 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                               |
| Bit 15     | TMCGFCIM | 0x0         | rw   | Transmitted Multiple Collision Good Frame Counter Interrupt Mask<br>Setting this bit masks the interrupt when the transmitted good frame after more than a single collision counter reaches half its maximum value or its maximum value. |
| Bit 14     | TSCGFCl  | 0x0         | rw   | Transmitted Single Collision Good Frame Counter Interrupt Mask<br>Setting this bit masks the interrupt when the transmitted good frame after a single collision counter reaches half its maximum value or its maximum value.             |
| Bit 13: 0  | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                                               |

### 26.3.39 Ethernet MMC transmitted good frame single collision counter register (EMAC\_MMCTFSCC)

This register maintains the number of successfully transmitted frames after a single collision in half-duplex mode.

| Bit       | Name   | Reset value | Type | Description                                                                                                                            |
|-----------|--------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TGFSCC | 0x0000 0000 | ro   | Transmitted Good Frames Single Collision Counter<br>This field maintains the transmitted good frames after a single collision counter. |

### 26.3.40 Ethernet MMC transmitted good frame more than a single collision counter register (EMAC\_MMCTFMSCC)

This register maintains the number of successfully transmitted frames after more than a single collision in half-duplex mode.

| Bit       | Name    | Reset value | Type | Description                                                                                                                                                 |
|-----------|---------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TGFMSCC | 0x0000 0000 | ro   | Transmitted Good Frame More Than a Single Collision Counter<br>This field maintains the transmitted good frames after more than a single collision counter. |

### 26.3.41 Ethernet MMC transmitted good frames counter register (EMAC\_MMCTFCNT)

This register maintains the number of the transmitted good frames.

| Bit       | Name | Reset value | Type | Description                     |
|-----------|------|-------------|------|---------------------------------|
| Bit 31: 0 | TGFC | 0x0000 0000 | ro   | Transmitted Good Frames Counter |

### 26.3.42 Ethernet MMC received frames with CRC error counter register (EMAC\_MMCRFCECR)

This register maintains the number of the received good frames with CRC error.

| Bit       | Name  | Reset value | Type | Description                                                          |
|-----------|-------|-------------|------|----------------------------------------------------------------------|
| Bit 31: 0 | RFCEC | 0x0000 0000 | ro   | Received Frames CRC Error Counter<br>Received frames with CRC error. |

### 26.3.43 Ethernet MMC received frames with alignment error counter register (EMAC\_MMCRFAECNT)

This register maintains the number of the received frames with alignment error.

| Bit       | Name  | Reset value | Type | Description                                                                      |
|-----------|-------|-------------|------|----------------------------------------------------------------------------------|
| Bit 31: 0 | RFAEC | 0x0000 0000 | ro   | Received Frames Alignment Error Counter<br>Received frames with alignment error. |

### 26.3.44 Ethernet MMC received good unicast frames counter register (EMAC\_MMCRGUFCNT)

This register maintains the number of the received good unicast frames.

| Bit       | Name  | Reset value | Type | Description                          |
|-----------|-------|-------------|------|--------------------------------------|
| Bit 31: 0 | RGUFC | 0x0000 0000 | ro   | Received Good Unicast Frames Counter |

### 26.3.45 Ethernet PTP time stamp control register (EMAC\_PTPTSCTRL)

This register controls the generation of system time in the receiver and the generation of time stamp in a PTP packet.

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                    |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 19 | Reserved | 0x0000      | resd | Kept at its default value.                                                                                                                                                                                     |
| Bit 18     | EMAFPFF  | 0x0         | rw   | Enable MAC Address For PTP Frame Filtering<br>When this bit is set, the MAC address (matches any of the MAC address registers) is used for PTP frame filtering while the PTP is directly sent by the Ethernet. |
| Bit 17: 16 | SPPFTS   | 0x0         | rw   | Select PTP Packets For Taking Snapshot<br>00: Normal clock<br>01: Boundary clock<br>10: End-to-End Transparent Clock<br>11: Point-to-Point Transparent Clock                                                   |
| Bit 15     | ESFMRTM  | 0x0         | rw   | Enable Snapshot For Message Relevant To Master<br>When this bit is set, it enables snapshots for messages relevant to master. Otherwise, it enables snapshots for                                              |

|          |           |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-----------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |           |     |      | messages relevant to slave.                                                                                                                                                                                                                                                                                                                                                                                         |
| Bit 14   | ETSFEM    | 0x0 | rw   | Enable Timestamp Snapshot For Event Messages<br>When this bit is set, it enables time stamp snapshots for event messages only (SYNC, Delay_Req, Pdelay_Req, or Pdelay_Resp). When this bit is cleared, time stamp snapshots are applicable to all the messages except Announce, Management and Signaling.                                                                                                           |
| Bit 13   | EPPFSIP4U | 0x1 | rw   | Enable Processing of PTP Frames Sent over IPv4-UDP<br>When this bit is set, the MAC receiver processes the PTP encapsulated in UDP over IPv4 packet. When this bit is cleared, the MAC ignores the PTP transferred over UDP-IPv4 packet. This bit is set by default.                                                                                                                                                |
| Bit 12   | EPPFSIP6U | 0x0 | rw   | Enable Processing of PTP Frames Sent over IPv6-UDP<br>When this bit is set, the MAC receiver processes the PTP encapsulated in UDP over IPv6 packet. When this bit is cleared, the MAC ignores the PTP sent over UDP-IPv6 packet.                                                                                                                                                                                   |
| Bit 11   | EPPEF     | 0x0 | rw   | Enable Processing of PTP over EMAC Frames<br>When this bit is set, the MAC receiver processes the PTP that is directly encapsulated in the Ethernet frames. When this bit is cleared, the MAC ignores the PTP over EMAC frames.                                                                                                                                                                                     |
| Bit 10   | EPPV2F    | 0x0 | rw   | Enable PTP packet Processing for Version 2 Format<br>When this bit is set, it enables PTP packet processing in the format of 1588 V2. Otherwise, 1588 V1 format is used for PTP packet processing. Refer to <i>PTP process and control</i> on page 155 for more details on IEEE 1588 V1 and V2.                                                                                                                     |
| Bit 9    | TDBRC     | 0x0 | rw   | Timestamp Digital or Binary Rollover Control<br>When this bit is set, time stamp low register starts rolling after the 0x3B9A_C9FF value (1 ns precision), and the time stamp (high) second is incremented. When this bit is cleared, the rollover value of the subsecond register is 0x7FFF_FFFF. The subsecond increment must be configured according to PTP reference clock frequency and the value of this bit. |
| Bit 8    | ETAF      | 0x0 | rw   | Enable Timestamp for All Frames<br>When this bit is set, it enables time stamp snapshot for all received frames on the MAC.                                                                                                                                                                                                                                                                                         |
| Bit 7: 6 | Reserved  | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 5    | ARU       | 0x0 | rw   | Addend Register Update<br>When this bit is set, the Ethernet PTP time stamp addend register's contents are updated on the PTP block for fine correction. This bit is cleared when the update is completed. This register bit must be read as 0 before being set.                                                                                                                                                    |
| Bit 4    | TITE      | 0x0 | rw   | Timestamp Interrupt Trigger Enable<br>When this bit is set, a time stamp interrupt is enabled if the system time becomes greater than the value written in the target time register. This bit is cleared when the time stamp trigger interrupt is generated.                                                                                                                                                        |
| Bit 3    | TU        | 0x0 | rw   | Timestamp Update<br>When this bit is set, the system time is updated (added or subtracted from) with the value programmed in the system time second update register and system time nanosecond update register.<br>This bit must be read as 0 before being updated. This bit is cleared after the hardware update is completed. Time stamp high word register (if enabled) is not updated.                          |
| Bit 2    | TI        | 0x0 | rw   | Timestamp Initialize<br>When this bit is set, the system time is initialized (overwritten) with the value specified in the system time second update register and system time nanosecond update register.                                                                                                                                                                                                           |

|       |      |     |    |                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     |    | This bit must be read as 0 before being updated. This bit is cleared after the initialization. Time stamp high word register (if enabled) is not updated.                                                                                                                                                                                                                                         |
| Bit 1 | TFCU | 0x0 | rw | Timestamp Fine or Coarse Update<br>When this bit is set, it indicates that the system time is updated using a fine update method. When this bit is cleared, it indicates that the system time is updated using a coarse update method.                                                                                                                                                            |
| Bit 0 | TE   | 0x0 | rw | Timestamp Enable<br>When this bit is set, time stamp function is enabled for transmit and receive frames. Once disabled, the time stamp function is not added for transmit and receive frames, and the time stamp generator is suspended as well. Once enabled, the time stamp (system time) should be initialized. On the receive side, the MAC processes 1588 frames only when this bit is set. |

#### Correlation between time stamp snapshot and register bits

| SPPFTS<br>Bit 17: 16 | ESFMRTM<br>Bit 15 | ETSFEM<br>Bit 14 | PTP message                                                     |
|----------------------|-------------------|------------------|-----------------------------------------------------------------|
| 00 or 01             | X                 | 0                | SYNC, Follow_Up, Delay_Req, Delay_Resp                          |
| 00 or 01             | 1                 | 1                | Delay_Req                                                       |
| 00 or 01             | 0                 | 1                | SYNC                                                            |
| 10                   | N/A               | 0                | SYNC, Follow_Up, Delay_Req, Delay_Resp                          |
| 10                   | N/A               | 1                | SYNC, Follow_Up                                                 |
| 11                   | N/A               | 0                | SYNC, Follow_Up, Delay_Req, Delay_Resp, Pdelay_Req, Pdelay_Resp |
| 11                   | N/A               | 1                | SYNC, Pdelay_Req, Pdelay_Resp                                   |

1 : N/A= Not applicable

2 : X=Irrelevant

### 26.3.46 Ethernet PTP subsecond increment register (EMAC\_PTPSSINC)

This register is present only when the IEEE1588 time stamp function is selected without an external time stamp input. In Coarse Update mode (TSCFUPDT bit), the value in this register is added to the system time every clk\_ptp\_ref\_i clock cycle. In Fine Update mode, the value in this register is added to the system time whenever the accumulator has an overflow.

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 7: 0  | SSIV     | 0x00        | rw   | Sub-Second Increment Value<br>The value programmed in this field is incremented with the value of the subsecond register at every clock cycle (of clk_ptp_i). For example, if the PTP clock is 50 MHz (20 ns), when the system time nanosecond register is 1 ns accuracy (by setting the bit 9 in the EMAC_PTPTSCTRL register), the value of these bits should be configured to 20 (0x14). When the TSCTRLLSSR is cleared, nanosecond register resolution is ~0.465ns accuracy. In this case, the value of these bits should be configured to 43 (0x2B), that is, 20ns/0.465. |

### 26.3.47 Ethernet PTP time stamp high register (EMAC\_PTPTSH)

System time second register and system time nanosecond register indicate the current value of the system time maintained by the MAC. This value is updated on a continuous basis.

| Bit       | Name | Reset value | Type | Description                                                                                                 |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TS   | 0x0000 0000 | ro   | Timestamp Second<br>This field indicates the second value of the current system time maintained by the MAC. |

### 26.3.48 Ethernet PTP time stamp low register (EMAC\_PTPTSL)

This register contains the lower 32 time bits. It is a read-only register containing the subsecond system time value.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                             |
|-----------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31    | AST  | 0x0         | ro   | Add or Subtract Time<br>When this bit is set, the time value is subtracted from the value of the update register. When this bit is cleared, the time value is added to the value of the update register.                                |
| Bit 30: 0 | TSS  | 0x0000 0000 | ro   | Timestamp Sub Seconds<br>This field indicates the subsecond system time with 0.46 ns accuracy. When the bit 9 is set in the EMAC_PTPTSCTRL register, each bit represents 1 ns, with the value programmed not exceeding the 0x3B9A_C9FF. |

### 26.3.49 Ethernet PTP time stamp high update register (EMAC\_PTPTSHUD)

System time second update register and system nanosecond update register initializes or updates the system time maintained by the MAC. It is required to write both registers before setting the TSINIT or TSUPDT bit in the EMAC\_PTPTSCTRL register.

| Bit       | Name | Reset value | Type | Description                                                                                                      |
|-----------|------|-------------|------|------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TS   | 0x0000 0000 | rw   | Timestamp Second<br>This field indicates the second value that is to be initialized or added to the system time. |

### 26.3.50 Ethernet PTP time stamp low update register (EMAC\_PTPTSLUD)

This register is present only when the IEEE1588 time stamp function is selected without an external time stamp input.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                             |
|-----------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31    | AST  | 0x0         | rw   | Add or Subtract Time<br>When this bit is set, the time value is subtracted from the value of the update register. When this bit is cleared, the time value is added to the value of the update register.                                |
| Bit 30: 0 | TSS  | 0x0000 0000 | rw   | Timestamp Sub Seconds<br>This field indicates the subsecond system time with 0.46 ns accuracy. When the bit 9 is set in the EMAC_PTPTSCTRL register, each bit represents 1 ns, with the value programmed not exceeding the 0x3B9A_C9FF. |

### 26.3.51 Ethernet PTP time stamp addend register (EMAC\_PTPTSAD)

This register value is used only when the system time is configured for Fine update mode. This register value is added to a 32-bit accumulator at every clock cycle (of clk\_ptp\_ref\_i). The system time is updated whenever the accumulator overflows.

| Bit       | Name | Reset value | Type | Description                                                                                                                                      |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TAR  | 0x0000 0000 | rw   | Timestamp Addend Register<br>This field indicates the 32-bit time value to be added to the accumulator in order to achieve time synchronization. |

### 26.3.52 Ethernet PTP target time high register (EMAC\_PTPTTH)

Target time second register and target time subsecond register are used to schedule an interrupt event when the system time exceeds the value programmed in these registers.

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                            |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TTSR | 0x0000 0000 | rw   | Target Time Seconds Register<br>This register stores the time value in seconds. When the time stamp value equals or exceeds both target time stamp registers, the MAC starts or stops PPS signal output depending on the bit [6: 5] of the PPS control register. An interrupt is generated if enabled. |

### 26.3.53 Ethernet PTP target time low register (EMAC\_PTPTTL)

| Bit       | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | TTLR | 0x0000 0000 | rw   | Target Timestamp Low Register<br>This register stores the time (signed) in nanoseconds. When the value of the time stamp equals both target time stamp registers, the MAC starts or stops PPS signal output depending on the TRGTMODSEL0 (bit [6: 5]) of the PPS control register. An interrupt is generated if enabled.<br>When the bit 9 (TSCTRLLSSR) is set in the MAC_PTPTSCR register, the value of this field cannot exceed the 0x3B9A_C9FF. The actual time that starts or stops PPT signal output may have an error of up to 1 subsecond increment value. |

### 26.3.54 Ethernet PTP time stamp status register (EMAC\_PTPTSSR)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                          |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 2 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                           |
| Bit 1     | TTTR     | 0x0         | ro   | Timestamp Target Time Reached<br>When this bit is set, it indicates the value programmed when the system time equals or exceeds the target time second register and target time nanosecond register. |
| Bit 0     | TSO      | 0x0         | ro   | Timestamp Seconds Overflow<br>When this bit is set, it indicates that the time stamp value (V2 format supported) overflows and has exceeded the 32'hFFFF_FFFF.                                       |

### 26.3.55 Ethernet PTP PPS register (EMAC\_PTPPPSCR)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 4 | Reserved | 0x00000000  | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Bit 3: 0  | POFC     | 0x0         | rw   | PPS0 Output Frequency Control<br>The output of this field depends on the emac_pps_sel bit (bit 15 in the CRM_MISC2 register)<br>Emac_pps_sel=0:<br>0000: 1 Hz, use binary rollover control, pulse width is 125 ms; use digital rollover, pulse width is 100 ms<br>0001: 2 Hz, use binary rollover control, duty cycle is 50% (digital rollover is not recommended)<br>0010: 4 Hz, se binary rollover control, duty cycle is 50% (digital rollover is not recommended)<br>0011: 8 Hz, use binary rollover control, duty cycle is 50%(digital rollover is not recommended)<br>0100: 16 Hz, use binary rollover control, duty cycle is 50% (digital rollover is not recommended)<br>1111: 32.768 kHz, use binary rollover control, duty cycle is 50% (digital rollover is not recommended)<br>Emac_pps_sel=1:<br>0000: 1 Hz, pulse width is one clk_ptp cycle<br>0001: For binary rollover, 2hz, duty cycle 50%; For digital |

rollover, 1hz (digital rollover is not recommended)  
0010: For binary rollover, 4hz, duty cycle 50%; For digital rollover, 2hz (digital rollover is not recommended)  
0011: For binary rollover, 8hz, duty cycle 50%; For digital rollover, 4hz (digital rollover is not recommended)  
1111: For binary rollover, 32.768khz, duty cycle 50%; For digital rollover, 16.384khz (digital rollover is not recommended)  
Digital rollover is not recommended when the PPS is non-zero value, because PPS output waveforms will be irregular (although its average frequency is always correct in any one-second window ) in these cases.

# 27 Digital Video parallel interface (DVP)

## 27.1 Introduction

The digital video parallel interface (DVP) is able to capture parallel data output on the CMOS video camera. It is possible to perform frame/line synchronization in either hardware or embedded synchronization code. With the frame rate control feature, the number of frames captured per second can be controlled. The crop window feature allows the users to retain the desired data and drop others. Using the image scaling feature, it is possible to scale down the number of pixels or lines. The DMA controller can be used to transfer the captured data to memory unit without the need of CPU. The users can monitor the status of data reception through status and error interrupts.

Figure 27-1 DVP block diagram



## 27.2 Introduction

- 8-bit, 10-bit, 12-bit or 14-bit parallel interface
- Parallel interface data alignment
- Hardware or embedded code synchronization
- Single frame or continuous capture mode
- Frame rate control
- Crop window feature
- Image scaling resize
- Monochrome image binarization
- DMA access single or burst transfer
- Frame capture completed, vertical synchronization and horizontal synchronization status interrupts
- FIFO overrun and embedded synchronization error interrupts

## 27.3 Data capture and synchronization

The digital video parallel interface uses the DVP pixel clock (DVP\_PCLK) to capture the pixel parallel data (DVP\_D) output from the CMOS video camera. The DVP\_PCLK is provided by the CMOS video camera. Data can be captured on either the rising or the falling edge of the DVP\_PCLK by setting the CKP bit in the DVP\_CTR register. The captured data can be divided into two parts: valid pixel data and blanking period data. The user only concerns the former. The CMOS can deliver synchronization information in a single or multiple modes for the receiver to perform frame segmentation and fetch valid pixel data. The digital video parallel interface (DVP) supports hardware or embedded code synchronization, which can be done through the SM bit in the DVP\_CTRL register.

### 27.3.1 Hardware synchronization mode

In this mode, the CMOS video camera offers two synchronization signals: horizontal and vertical synchronization signals. The hardware synchronization mode is selected by setting SM=0 in the DVP\_CTRL register. The horizontal synchronization signals are used to distinguish the valid pixel and blanking periods, and it is activated by the DVP\_VSYNC pin to enable DVP to split lines and fetch valid pixel data. The polarity of the horizontal synchronization signals can be programmed through the HSP bit in the DVP\_CTRL register in order to ensure that it matches the output of the digital video camera. The vertical synchronization signals are used for interframe separation, and it is activated by the DVP\_HSYNC pin to enable DVP to split frames. The vertical synchronization signals are expressed in two types.

#### Frame start

In this mode, the vertical synchronization signals are used as a frame start signal. The Frame start signal indicates the end of the current frame and the start of the next frame. The polarity of the Frame start signal is programmable through the VSP bit in the DVP\_CTRL register to ensure that it matches the output of the digital video camera. For example, in Figure 27-2, the VSP bit must be set (the DVP\_VSYNC high level marks the Frame start).

Figure 27-2 CMOS video camera output in Frame start type



#### Frame valid

In this mode, the vertical synchronization signals are used to determine whether the captured data is in the vertical blanking period. Frames are split through the vertical blanking period. Similarly, the VSP bit in the DVP\_CTR register can be used to program the polarity of the frame valid to ensure that it matches the output of the digital video camera. For example, in Figure 27-3, the VSP bit must be set to 0 (DVP\_VSYNC low level indicates that the captured data is in the vertical blanking period).

Figure 27-3 CMOS video camera output in Frame valid type



Table 27-1 lists the physical signals used by DVP in hardware synchronization mode. The use of the pixel parallel data (DVP\_D) depends on the configurations of parallel data bits and alignment. Refer to Section 27.3.3 for details. Those unused signals may not be configured with the multiplexed function of the corresponding pins.

Table 27-1 DVP pin use in hardware synchronization mode

| Signal name | Direction | Description                           |
|-------------|-----------|---------------------------------------|
| DVP_D[m:n]  | Input     | DVP pixel parallel data               |
| DVP_PCLK    | Input     | DVP pixel clock                       |
| DVP_HSYNC   | Input     | DVP horizontal synchronization signal |
| DVP_VSYNC   | Input     | DVP vertical synchronization signal   |

### 27.3.2 Embedded data synchronization mode

To reduce the use of pins, some CMOS video cameras embed synchronization between valid pixel data and blanking data instead of the use of horizontal and vertical synchronization signals. The embedded synchronization mode is selected by setting SM=1 in the DVP\_CTRL register. The embedded codes are composed of four data, in which the first three data have the fixed contents, with the first data all 1, and the subsequent two data all 0. The four data depends on synchronization information. The DVP\_SCR register is programmed based on the synchronization type and content of the camera suppliers. The embedded code synchronization provides synchronization information in two types:

#### FS/FE/LS/LE type

In this mode, the CMOS camera uses four embedded synchronization codes to provide synchronization information. The Frame Start (FS) synchronization code is embedded between blanking area and valid pixels, signaling the start of a new frame. The data following the FS is the valid pixel data of line 0. For the remaining lines other than line 0, the LS (Line Start) synchronization code is used to indicate the end of blanking area and the start of a valid pixel. At the end of the last valid pixel data of each line, the LE code (Line End) is embedded indicating that the subsequent data are horizontal blanking. At the end of the line, the LE is replaced with the FE (Frame End), indicating the end of the current frame. Figure 27-4 shows the relationship between blanking area, valid pixel and synchronization code.

To enable FS/FE/LS/LE reception, the corresponding bits in the DVP\_SCR register are configured as follows:

FMSC: The 4<sup>th</sup> captured data of FS is placed in the 8 most significant bits

LNSC: The 4<sup>th</sup> captured data of LS is placed in the 8 most significant bits

LNEC: The 4<sup>th</sup> captured data of LE is placed in the 8 most significant bits

FMEC: The 4<sup>th</sup> captured data of FE is placed in the 8 most significant bits

Figure 27-4 FS/FE/LS/LE frame composition



**SAV/EAV type**

In this mode, the CMOS camera also uses four embedded synchronization codes to deliver synchronization information. The line within a frame uses the active SAV code to indicate the end of blanking area and the start of a valid pixel. At the end of the last valid pixel data of each line, the active SAV code is embedded signaling that the data following this are vertical blanking. The vertical blanking area is used to separate frames. In a vertical blanking area, the embedded synchronization code is still based on the line level. The blanking SAV code indicates the start of the line, while the blanking EAV indicates the end of the line. Figure 27-5 shows the relationship between blanking area, valid pixel and synchronization code.

To enable SAV/EAV reception, the corresponding bits in the DVP\_SCR register are configured as follows:

FMSC: Set as 0xff (embedded synchronization mode without frame start synchronization mode)

LNSC: The 4<sup>th</sup> captured data of Active SAV is placed in the 8 most significant bits

LNEC: The 4<sup>th</sup> captured data of Active EAV is placed in the 8 most significant bits

FMEC: Set as 0xff (embedded synchronization mode of arbitrary frame end synchronization mode)

Figure 27-5 SAV/EAV frame composition



Some of the CMOS cameras use some bits of the forth codes in one or several synchronization codes to pass on additional information. The DVP\_SUR register can be used to mask the comparison behavior of decoder for the misappropriated bits of the synchronization code. The reset value 0x00 and 0xff configuration both can indicate the complete synchronization code comparison.

Table 27-2 gives the physical signals used in DVP in embedded synchronization mode. The use of the DVP\_D depends on the configurations of parallel data bits and alignment. Refer to [Section 27.3.3](#) for more information. The unused signals must not be configured with the multiplexed functions.

Table 27-2 DVP pin use in embedded synchronization mode

| Signal name | Signal direction | Signal description      |
|-------------|------------------|-------------------------|
| DVP_D[m:n]  | Input            | DVP pixel parallel data |
| DVP_PCLK    | Input            | DVP pixel clock         |

### 27.3.3 Data alignment

The parallel data bits and data alignment of the CMOS camera vary from supplier to supplier, and from model to model. To ensure the greatest degree of flexibility, the IDUS and IDUN bits in the DVP\_ACTRL register can be used for the management of data alignment. Table 27-3 lists the CMOS camera parallel pin count, parallel data bits and alignment, and corresponding DVP register configuration and the use of DVP\_D pin.

Table 27-3 DVP register configuration and DVP\_D pin use

|                                      |      |       |       |       |       |       |       |        |
|--------------------------------------|------|-------|-------|-------|-------|-------|-------|--------|
| CMOS video camera parallel pin count | 8    | 10    |       | 12    |       |       |       | 14     |
| CMOS video camera parallel data bits | 8    | 8     | 10    | 8     | 10    | 12    | 14    |        |
| CMOS video camera data alignment     | N/A  | LSB   | MSB   | N/A   | LSB   | MSB   | LSB   | N/A    |
| DVP_D                                | [13] |       |       |       |       |       |       | Bit 13 |
| DVP_D                                | [12] |       |       |       |       |       |       | Bit 12 |
|                                      | [11] |       |       |       | Bit 7 |       | Bit 9 | Bit 11 |
|                                      | [10] |       |       |       | Bit 6 |       | Bit 8 | Bit 10 |
|                                      | [9]  |       | Bit 7 | Bit 9 | Bit 5 | Bit 9 | Bit 7 | Bit 9  |
|                                      | [8]  |       | Bit 6 | Bit 8 | Bit 4 | Bit 8 | Bit 6 | Bit 8  |
|                                      | [7]  | Bit 7 | Bit 5 | Bit 7 | Bit 3 | Bit 7 | Bit 5 | Bit 7  |
|                                      | [6]  | Bit 6 | Bit 4 | Bit 6 | Bit 2 | Bit 6 | Bit 4 | Bit 6  |
|                                      | [5]  | Bit 5 | Bit 3 | Bit 5 | Bit 1 | Bit 5 | Bit 3 | Bit 5  |
|                                      | [4]  | Bit 4 | Bit 2 | Bit 4 | Bit 0 | Bit 4 | Bit 2 | Bit 4  |
|                                      | [3]  | Bit 3 | Bit 1 | Bit 3 | Bit 3 | Bit 3 | Bit 1 | Bit 3  |
|                                      | [2]  | Bit 2 | Bit 0 | Bit 2 | Bit 2 | Bit 2 | Bit 0 | Bit 2  |
|                                      | [1]  | Bit 1 |       | Bit 1 | Bit 1 | Bit 1 |       | Bit 1  |
|                                      | [0]  | Bit 0 |       | Bit 0 | Bit 0 | Bit 0 |       | Bit 0  |
| IDUN                                 | 0    | 1     | 1     | 0     | 2     | 2     | 1     | 0      |
| IDUS                                 | 0    | 0     | 1     | 0     | 0     | 1     | 0     | 0      |
| PDL                                  | 0    | 0     | 0     | 1     | 0     | 0     | 1     | 2      |
|                                      |      |       |       |       |       |       |       | 3      |

### 27.3.4 Single frame and continuous capture modes

The digital video parallel interface (DVP) supports two types of capture: single frame and continuous capture.

#### Single frame mode

A single frame mode is selected by setting CFM=1 in the DVP\_CTRL register. In this mode, after the CAP bit is set in the DVP\_CTR register, the DVP interface starts sampling data on the next frame start based on the received synchronization information. At the end of the frame, the DVP interface automatically resets the CAP bit and stops capturing data.

Figure 27-6 Block diagram in single frame capture mode



#### Continuous capture mode

The continuous capture mode is enabled by setting CFM=0 in the DVP\_CTRL register. In this mode, after the CAP bit is set in the DVP\_CTR register, the DVP interface, based on the received synchronization information, starts sampling data on the start of the next frame start. This process continues. When the CAP bit is cleared, the DVP interface keeps the CAP bit in Set state and continues sampling data until the end of the current frame. At this point, the DVP interface resets the CAP bit and stops data sampling.

Figure 27-7 Block diagram in continuous capture mode



## 27.4 DMA access interface and data output packing

### 27.4.1 DMA access interface

The captured data can be transferred to memory unit using DMA interface without needing to occupy CPU resources. After the CAP is set in the DVP\_CTRL register, the DMA interface is automatically activated. The DMA accesses the DVP\_DT register through the AHB bus to fetch the DVP-captured data. A 32-bit data is transferred for each access. The DVP DMA interface supports single or burst transfers, depending on the DMABT bit in the DVP\_ACTRL register.

#### Burst transfer mode

Burst transfer mode is enabled when setting DMABT=1. A DMA access is triggered each time the DVP receives four 32-bit data. After receiving a DMA request, the DMA makes four consecutive accesses to the DVP\_DT register. The burst mode is able to significantly reduce the number of arbitration so as to improve bus performance. Only EDMA is supported in burst transfer mode, and the peripheral burst transfer of the EMDA must be set as INCR4 (PBURST=1).

#### Single transfer mode

Single transfer mode is enabled when setting DMABT=0. In this mode, a DMA access request is triggered each time the DVP receives a 32-bit data. After receiving a DMA request, the DMA interface accesses the DVP\_DT register once. When the DMA interface uses DMA, only single transfer mode is supported. To use EMDA in this mode, the peripheral burst transfer must be set as single transfer mode (PBURST=0).

Note: To ensure correct data acquisition using DMA access interface, the AHB bus clock (AHB\_CLK) must be higher than 2.5 DVP\_PCLK clocks.

### 27.4.2 Data output packing

The captured data are packed into a 32-bit data register (DVP\_DT) and then transferred through a DMA. The packing mode depends on the PDL bit in the DVP\_CTRL register. Refer to Figure 27-8 for more information.

#### 8-bit parallel data (PDL=0)

When the PDL is programmed to 0, the DVP captures an 8-bit data every DVP\_PCLK clock, and packs four captured data into a word data. The first captured data is placed in the 8 least significant bits, and the last captured data is placed in the 8 most significant bits, and so on.

#### 10-bit parallel data (PDL=1)

When the PDL is programmed to 1, the DVP captures a 10-bit data is captured every DVP\_PCLK clock, and packs two captured data into a word data. The word data is made up of two half words. The first captured data is placed in the 10 least significant bits of the least significant half word, and the last captured data is placed in the 10 least significant bits of the most significant half word, and the remaining are cleared to zero.

#### 12-bit parallel data (PDL=2)

When the PDL bit is programmed to 2, the DVP captures a 12-bit data every DVP\_PCLK clock, and

packs two captured data into a word data. The word data is made up of two half words. The first captured data is placed in the 12 least significant bits of the least significant half word, and the last captured data is placed in the 12 least significant bits of the most significant half word, and the remaining are cleared to zero.

#### 14-bit parallel data (PDL=3)

When the PDL bit is programmed to 3, the DVP captures a 14-bit data every DVP\_PCLK clock, and packs two captured data into a word data. The word data is made up of two half words. The first captured data is placed in the 14 least significant bits of the least significant half word, and the last captured data is placed in the 14 least significant bits of the most significant half word, and the remaining are cleared to zero.

Figure 27-8 PDL configuration and data output packing

|                |          |       |             |       |   |
|----------------|----------|-------|-------------|-------|---|
| 8-bit (PDL=0)  | 31       | 24 23 | 16 15       | 8 7   | 0 |
|                | D3       | D2    | D1          | D0    |   |
| 10-bit (PDL=1) | 31       | 26 25 | 16 15       | 10 9  | 0 |
|                | 6'b0     | D1    | 6'b0        | D0    |   |
| 12-bit (PDL=2) | 31       | 28 27 | 16 15       | 12 11 | 0 |
|                | 4'b0     | D1    | 4'b0        | D0    |   |
| 14-bit (PDL=3) | 31 30 29 |       | 16 15 14 13 |       | 0 |
|                | 2'b0     | D1    | 2'b0        | D0    |   |

## 27.5 Interrupts and interrupt control

There are four registers available to control the interrupts of the DVP interface. The read-only DVP\_ESTS register is used to describe the synchronization status of error events occurred over the course of sampling. The DVP\_IENA is used to control interrupt signals, and it can be programmed to enable the synchronization status or error interrupts of the corresponding bits, and send them to CPU. The interrupts, after enabled, are stored in the read-only DVPISTS register, which is used to check the event sources. The status in the DVP\_ESTS and DVPISTS can be cleared by setting the corresponding bit in the DVP\_ICLR register. The DVP\_ICLR is a write-only register and does not need to be cleared.

DVP supports three synchronization status interrupts:

#### Capture frame done

When the CFDES and CFDIS bits are set (CAP enabled), it indicates the completion of the current frame capture. Based on the synchronization logic, the frame capture completed interrupt occurs when the frame end signal is detected. If the Crop feature is enabled, the frame capture completed interrupt occurs before the end of the crop window. If the Crop feature is not enabled, both CFDES and CFDIS bits have no effect.

#### Vertical synchronization

The VSES and VSIS bits indicate that vertical synchronization has been obtained. Vertical synchronization can be defined as the start or end of a frame, depending on the VSEID bit in the DVP\_ACTRL register.

#### Horizontal synchronization

The HSES and HSIS bits indicate that horizontal synchronization has been obtained. The horizontal synchronization can be defined as the start or end of a line, depending on the HSEID bit in the DVP\_ACTRL register.

The DVP supports two types of error interrupts:

#### Output data FIFO overrun

The OVRES and OVRIS bits (CAP enabled) indicate the error status of output data FIFO overrun. If

output data FIFO becomes full for the reason that the DMA is unable to capture data in time and transfer them to memory unit, in this case, the captured data will be discarded, and an output data overrun error interrupt is generated. If the CAP is not enabled, both OVRES and OVRIS bits have no effect.

#### Embedded synchronization error

When the ESEES and ESEIS bits (CAP enabled, and SM=1) are set, it indicates the error status of embedded synchronization error. If it outputs an unexpected synchronization code, the decoder discards the current synchronization, and re-decode the subsequent data. In this case, the DVP stops data capturing and generates an embedded synchronization error. If the CAP is not enabled, both ESEES and ESEIS bits have no effect.

## 27.6 Functional overview

### 27.6.1 Frame rate control

The DVP interface can adjust the number of frame captured every second with the frame rate control feature. The frame rate control feature applies to continuous capture mode (CFM=0). It consists of a basic frame rate control and progressive frame rate control.

Figure 27-9 Block diagram of frame rate control feature



#### Basic frame rate control

Capture a frame per two frames or per two four frames, which is programmable by the BFRC bit in the DVP\_CTR register.

#### Enhanced frame rate control

To acquire a fine frame rate, the advanced frame rate control is a choice. To enable this feature, set BFRC=0, and set the EFRCE bit in the DVP\_ACTRL register, the DVP can adjust the number of frames through the EFRCSF and EFRCTF bits in the DVP\_FRF register, based on the following formula:

$$\text{Target frame rate} = \frac{\text{EFRCTF}}{\text{EFRCSF}} \times \text{Original frame rate}$$

Note: When the advanced frame rate control feature is used, the EFRCSF and EFRCTF bits must not be set to zero, and the EFRCTF must not be greater than the EFRCSF bit.

### 27.6.2 Crop window

The crop window feature can be used to retain the desired data area and discard the remaining area. When the CRP bit is set in the DVP\_CTRL register, the DVP follows the configurations of the DVP\_CWST and DVP\_CWSZ registers to perform crop feature.

Figure 27-10 Crop window block diagram



Note: As the DVP packs the captured data into a 32-bit word for DMA access, the CHNUM bit has the following limits while using crop feature: for 8-bit data (PDL=0), CHNUM+1 must be a multiple of 4; for 10-bit, 12-bit or 14-bit data (PDL≠0), CHNUM+1 must be a multiple of 2.

### 27.6.3 Image resizing

The image resizing feature can be used to scale down the pixels or lines of an image. It consists of a basic image capture/drop control and advanced image resizing feature.

Figure 27-11 Image resizing block diagram



#### Basic image capture/drop control feature

The basic image capture/drop control feature is enabled through the PCDC or LCDC bit in the DVP\_CTRL register. After the LCDC bit is set to 1, drop one out of every two captured image lines to halve the size of the vertical axis of an image. The LCDS bit can be used to select whether to capture the previous one but drop the next one, or vice versa. The PCDC bit can be used to adjust the horizontal axis size of an image. The PCDS and PCDES bits determine which data to capture, as shown in Figure 27-12 and Figure 27-13.

Figure 27-12 LCDC/LCDS and frame structure



Figure 27-13 PCDC/PCDS and line structure



Note: The output format of the CMOS video camera must be determined while configuring PCDC and PCDS bits. Some configurations may cause the change in data formats. Refer to Section 27.7.3 for more information.

### Enhanced image reduction feature

The advanced image reduction feature can be used to obtain a fine image scaling. To enable this feature, EFDM=1 must be set, and the EFDF must be programmed based on the output formats of the CMOS video camera. Refer to Section 27.7.3 for more information. When the enhanced image reduction feature is used, PCDC=0 and LCDC=0 must be configured, and the EISRE bit must be set in the DVP\_ACTRL register. The DVP adjusts the size of the horizontal axis of an image through the HSRSF and HSRTF bits in the DVP\_HSCF register, and modifies the size of the vertical axis of an image through the VSRSF and VSRTF bits in the DVP\_VSCF register, based on the following formula:

$$\text{Target horizontal axis size} = \frac{\text{HSRTF}}{\text{HSRSF}} \times \text{Original horizontal axis size}$$

$$\text{Target vertical axis size} = \frac{\text{VSRTF}}{\text{VSRSF}} \times \text{Original vertical axis size}$$

Note: When using the enhanced image reduction feature, the HSRSF, HSRTF, VSRSF and VSRTF bits must not be set to 0, the HSRTF bit must not be greater than that of the HSRSF bit, and the VSRTF bit must not be higher than that of the VSRSF bit. Additionally, the calculated target horizontal size and target vertical size must be integers, and the target horizontal size must be a multiple of 4; otherwise, unpredictable results may be generated.

## 27.6.4 Grayscale image binarization conversion

The grayscale image binarization conversion unit is used to convert the luminance into one-bit format. To enable this feature, set EFDM=1, and program the EFDF bit based on the output format of CMOS video camera. Refer to Section 27.7.3 for more information. The MIBE bit is set in the DVP\_ACTRL register to enable grayscale image binarization conversion feature.

The MIBTHD bit in the DVP\_BTH register is used to program the grayscale image binarization threshold. The value above the threshold is deemed to 1, while the value below the threshold is deemed to 0. This feature becomes invalid if the luminance format of an image data cannot be fetched directly.

## 27.7 Data formats

### 27.7.1 Common CMOS video camera output formats

The CMOS video camera offers various image output formats. This section only gives a brief account of common data formats.

#### RGB565 format

In this format, one half-word data pixel (16 bit) is output every two pixel clocks. Each half-word data contains three types of pixel components: R (red), Green (G) and Blue (B), which are encoded in 5-bit, 6-bit and 5-bit format respectively. The first pixel clock outputs the lower part of R and G components, the second pixel clock outputs the upper part of G component, and B component. Or the first pixel clock outputs the lower part of B and G components, and the second pixel clock outputs the upper part of G component, and R component. Figure 27-14 gives an example of DVP data capture and packing in RGB565 format.

Figure 27-14 RGB565-format data capture and packing



#### RGB555 format

In this format, one half-word data pixel (16 bit) is output every two pixel clocks. Each half-word data contains three types of pixel components: R (red), Green (G) and Blue (B), which are encoded in 5-bit format. The first pixel clock outputs the lower part of R and G components, the second pixel clock outputs the upper part of G component, and B component. Or the first pixel clock outputs the lower part of B and G components, and the second pixel clock outputs the upper part of G component, and R component. As the valid data has a total of 15 bits, the upper part of the second pixel clock are not actually used. Typically, the CMOS video camera directly outputs a low level. Figure 27-15 gives an example of DVP data capture and packing in RGB555 format.

Figure 27-15 RGB555-format data capture and packing

**YUV422 format**

In this format, one half-word data pixel (16 bit) is output every two pixel clocks. Each half-word data contains a luminance component Y, and a chroma component U or V, which are encoded in 8-bit format. The chroma components U and V are interleaved among pixels, and two adjacent pixels use different chroma components. The camera outputs a group of pixel components every pixel clock, with Y component output on the first pixel clock, and U or V component output on the second pixel clock. Or the first pixel clock outputs U or V component, and the second pixel clock outputs Y component. Figure 27-16 gives an example of DVP data capture and packing in YUV422 format, in which the sequence of components U and V is swappable.

Figure 27-16 YUV422-format data capture and packing



### Y8 (Y-only) format

In this format, one-byte pixel (8-bit) Y (luminance) is output every pixel clock, which is encoded in 8-bit format. There is no chroma output. Figure 27-17 gives an example of DVP data capture and packing in Y8 (Y-only) format.

Figure 27-17 Y8 (Y-only)-format data capture and packing



### Raw data format

RAW data is the original pixel data obtained by CMOS video camera through Bayer color filter. One pixel data is output every pixel clock. It can be 8-bit, 10-bit, 12-bit or 14-bit. Refer to Section 27.4.2 for more information.

## 27.7.2 JPEG compressed format

To allow JPEG compressed data reception, it is necessary to set SM=0 and the JPEG big in the DVP\_CTRL register. In this format, the vertical synchronization signal is still used to separate frames, in the form of Frame Start or Frame effective, depending on manufacturers. The horizontal synchronization signal is used as a data enable signal, without line separation information. Because the JPEG size is programmable, the remaining data are padded with 0 at the end of the current frame in order to fill a word data (32-bit).

Note: The crop feature and image scaling feature must not be used in the JPEG format.

## 27.7.3 Enhanced data management

Enhanced image scaling resize and monochrome image binarization are handled in different ways, depending on the captured data format. To enable both features, EFDM=1 must be asserted, and the EFDF must be programmed according to the CMOS video camera output format. Table 27-4 describes two features and DVP data formats supported.

Table 27-4 Enhanced features and DVP data formats supported

| EFDM | EFDF       | Data format             | Enhanced image scaling resize | Monochrome image binarization |
|------|------------|-------------------------|-------------------------------|-------------------------------|
| 0    | don't care | don't care              | Not supported                 | not supported                 |
| 1    | 0          | YUV422<br>(UYVY / VYUY) | Supported                     | Supported                     |
| 1    | 1          | YUV422<br>(YUYV / VVYU) | Supported                     | Supported                     |
| 1    | 2          | RGB565<br>RGB555        | Supported                     | Not supported                 |
| 1    | 3          | Y8 (Y-only)             | Supported                     | Supported                     |

## 27.7.4 Data format conversion

In YUV422 format, the DVP interface can use a basic pixel capture/drop feature to pick up luminance component Y, and pack it in Y8 (Y-only) format, as shown in Figure 27-18.

Figure 27-18 YUV422 format to Y8 (Y-only) format



## 27.8 Registers

Table 27-5 shows the DVP register map and its reset values.

The peripheral registers can be accessed by words (32-bit).

Table 27-5 DVP register map and reset values

| Register | Offset | Reset value |
|----------|--------|-------------|
| DVP_CTRL | 0x000  | 0x0000 0000 |
| DVP_STS  | 0x004  | 0x0000 0000 |
| DVP_ESTS | 0x008  | 0x0000 0000 |
| DVP_IENA | 0x00C  | 0x0000 0000 |
| DVPISTS  | 0x010  | 0x0000 0000 |
| DVPICLR  | 0x014  | 0x0000 0000 |
| DVPSCR   | 0x018  | 0x0000 0000 |
| DVPSUR   | 0x01C  | 0x0000 0000 |
| DVP_CWST | 0x020  | 0x0000 0000 |
| DVP_CWSZ | 0x024  | 0x0000 0000 |
| DVPDT    | 0x028  | 0x0000 0000 |
| DVPACTRL | 0x040  | 0x0000 0000 |
| DVP_HSCF | 0x048  | 0x0000 0000 |
| DVP_VSCF | 0x04C  | 0x0000 0000 |
| DVP_FRF  | 0x050  | 0x0000 0000 |
| DVP_BTH  | 0x054  | 0x0000 0000 |

### 27.8.1 DVP control register (DVP\_CTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                            |
|------------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 21 | Reserved | 0x000       | resd | Kept at its default value.                                                                                                                                                             |
| Bit 20     | LCDS     | 0x0         | rw   | Basic line capture/drop selection<br>0: Capture the first line and drop the next<br>1: Drop the first line and capture the next<br>This register is valid when the LCDC=1 is asserted. |
| Bit 19     | LCDC     | 0x0         | rw   | Basic line capture/drop control<br>0: All frames are captured or use enhanced image scaling resize feature<br>1: Enable capture/drop control to capture one out of two                 |

|            |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |     |      | lines                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit 18     | PCDS     | 0x0 | rw   | Basic pixel capture/drop selection<br>0: Capture the first group of data (one or two pixel data) and drop the next group<br>1: Drop the first group of data (one or two pixel data) and capture the next group<br>This register is valid when the PCDC=1/2/3 is asserted.                                                                                                                                                                                       |
| Bit 17: 16 | PCDC     | 0x0 | rw   | Basic pixel capture/drop control<br>0: All frames are captured or use enhanced image scaling resize feature<br>1: Enable capture/drop control to capture one in two pixel data<br>2: Enable capture/drop control to capture one in four pixel data<br>3: Enable capture/drop control to capture two consecutive data in four pixel data                                                                                                                         |
| Bit 15     | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 14     | ENA      | 0x0 | rw   | DVP Enable<br>0: DVP disabled<br>1: DVP enabled<br>The DVP register configuration must be completed before enabling DVP.                                                                                                                                                                                                                                                                                                                                        |
| Bit 13: 12 | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 11: 10 | PDL      | 0x0 | rw   | Pixel data length<br>0: Interface captures 8-bit data<br>1: Interface captures 10-bit data<br>2: Interface captures 12-bit data<br>3: Interface captures 14-bit data                                                                                                                                                                                                                                                                                            |
| Bit 9: 8   | BFRC     | 0x0 | rw   | Basic frame rate control<br>0: All frames are captured or use enhanced frame rate control feature<br>1: Enable frame rate control, every alternate frame captured<br>2: Enable frame rate control, one frame in 4 frames captured<br>3: Reserved<br>This feature is valid only when CFM=0 is asserted.                                                                                                                                                          |
| Bit 7      | VSP      | 0x0 | rw   | DVP_VSYNC polarity<br>This bit defines the vertical synchronization signals.<br>Frame start:<br>0: DVP_VSYNC low level indicates a Frame start signal<br>1: DVP_VSYNC high level indicates a Frame start signal<br>Frame effective:<br>0: DVP_VSYNC low level indicates that the captured data is in vertical blanking<br>1: DVP_VSYNC high level indicates that the captured data is in vertical blanking<br>This feature is valid only when SM=0 is asserted. |
| Bit 6      | HSP      | 0x0 | rw   | DVP_HSYNC polarity<br>0: DVP_HSYNC high level indicates that the captured data is a valid pixel data, and Line start signal on the rising edge<br>1: DVP_HSYNC low level indicates that the captured data is a valid pixel data, and Line start signal on the falling edge<br>This feature is valid only when SM=0 is asserted.                                                                                                                                 |
| Bit 5      | CKP      | 0x0 | rw   | DVP_PCLK polarity<br>0: DVP_PCLK rising edge active<br>1: DVP_PCLK falling edge active                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 4      | SM       | 0x0 | rw   | Synchronization mode<br>0: Hardware synchronization mode<br>1: Embedded synchronization mode                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 3      | JPEG     | 0x0 | rw   | JPEG format<br>0: Uncompressed video format<br>1: Compressed video format                                                                                                                                                                                                                                                                                                                                                                                       |

|       |     |     |    |                                                                                                                                                                                                                                                                                                                                   |
|-------|-----|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     |    | This feature is valid only when SM=0 is asserted.                                                                                                                                                                                                                                                                                 |
| Bit 2 | CRP | 0x0 | rw | Cropping window function enable<br>0: Cropping window function disabled<br>1: Cropping window function enabled                                                                                                                                                                                                                    |
| Bit 1 | CFM | 0x0 | rw | Capture function mode<br>0: Continuous capture mode<br>1: Single frame capture mode                                                                                                                                                                                                                                               |
|       |     |     |    | Capture function enable<br>0: Capture function disabled<br>1: Capture function enabled                                                                                                                                                                                                                                            |
|       |     |     |    | The DMA controller and DVP register configurations must be programmed before enabling this bit.                                                                                                                                                                                                                                   |
| Bit 0 | CAP | 0x0 | rw | When CFM=1, after this bit is set, this register is automatically reset after the completion of a single frame capture.<br>When CFM=0, after this bit is set, this register remains in set status. After this bit is cleared by software, this register is automatically reset after the completion of the current frame capture. |

## 27.8.2 DVP status register (DVP\_STS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                 |
|-----------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 3 | Reserved | 0x0000 0000 | resd | Kept at its default value.                                                                                                                                                                  |
| Bit 2     | OFNE     | 0x0         | ro   | Output data FIFO status<br>0: FIFO empty<br>1: FIFO has valid data                                                                                                                          |
| Bit 1     | VSYN     | 0x0         | ro   | Vertical synchronization status<br>0: Vertical synchronization is not in blanking state<br>1: Vertical synchronization is in blanking state<br>This bit is valid when the CAP is set.       |
| Bit 0     | HSYN     | 0x0         | ro   | Horizontal synchronization status<br>0: Horizontal synchronization is not in blanking state<br>1: Horizontal synchronization is in blanking state<br>This bit is valid when the CAP is set. |

## 27.8.3 DVP event status register (DVP\_ESTS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                          |
|-----------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 5 | Reserved | 0x0000 000  | resd | Kept at its default value.                                                                                                                                                                                                                           |
| Bit 4     | HSES     | 0x0         | ro   | Horizontal synchronization event status<br>0: No horizontal synchronization status detected<br>1: Horizontal synchronization status detected<br>It is cleared by writing 1 to the HSIC bit in the DVP_ICLR register.                                 |
| Bit 3     | VSES     | 0x0         | ro   | Vertical synchronization event status<br>0: No vertical synchronization status detected<br>1: Vertical synchronization status detected<br>It is cleared by writing 1 to the VSIC bit in the DVP_ICLR register.                                       |
| Bit 2     | ESEES    | 0x0         | ro   | Embedded synchronization error event status<br>0: Embedded synchronization normal<br>1: Embedded synchronization error<br>It is cleared by writing 1 to the ESEIC bit in the DVP_ICLR register.<br>This feature is valid only when SM=1 is asserted. |
| Bit 1     | OVRES    | 0x0         | ro   | Output data FIFO overrun event status<br>0: No data FIFO overrun event detected<br>1: Data FIFO overrun event detected<br>It is cleared by writing 1 to the OVRIC bit in the DVP_ICLR register.                                                      |
| Bit 0     | CFDES    | 0x0         | ro   | Capture frame done raw event status<br>0: A frame has not been captured<br>1: A frame has been captured                                                                                                                                              |

It is cleared by writing 1 to the CFDIC bit in the DVP\_ICLR register.

#### 27.8.4 DVP interrupt enable register (DVP\_IENA)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                    |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 5 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                     |
| Bit 4     | HSIE     | 0x0         | rw   | Horizontal synchronization interrupt enable<br>0: Horizontal synchronization interrupt disabled<br>1: Horizontal synchronization interrupt enabled             |
| Bit 3     | VSIE     | 0x0         | rw   | Vertical synchronization interrupt enable<br>0: Vertical synchronization interrupt disabled<br>1: Vertical synchronization interrupt enabled                   |
| Bit 2     | ESEIE    | 0x0         | rw   | Embedded synchronization error interrupt enable<br>0: Embedded synchronization error interrupt disabled<br>1: Embedded synchronization error interrupt enabled |
| Bit 1     | OVRIE    | 0x0         | rw   | Output data FIFO overrun interrupt enable<br>0: Output data FIFO overrun interrupt disabled<br>1: Output data FIFO overrun interrupt enabled                   |
| Bit 0     | CFDIE    | 0x0         | rw   | Capture frame done interrupt enable<br>0: Capture frame done interrupt disabled<br>1: Capture frame done interrupt enabled                                     |

#### 27.8.5 DVP interrupt status register (DVPISTS)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                                                        |
|-----------|----------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 5 | Reserved | 0x0000 000  | resd | Kept at its default value.                                                                                                                                                                                                                                                                         |
| Bit 4     | HSIS     | 0x0         | ro   | Horizontal synchronization interrupt status<br>0: No horizontal synchronization interrupt generated<br>1: Horizontal synchronization interrupt generated<br>It is cleared by writing 1 to the HSIC bit in the DVP_ICLR register.                                                                   |
| Bit 3     | VSIS     | 0x0         | ro   | Vertical synchronization interrupt status<br>0: No vertical synchronization interrupt generated<br>1: Vertical synchronization interrupt generated<br>It is cleared by writing 1 to the VSIC bit in the DVP_ICLR register.                                                                         |
| Bit 2     | ESEIS    | 0x0         | ro   | Embedded synchronization error interrupt status<br>0: No embedded synchronization error interrupt generated<br>1: Embedded synchronization error interrupt generated<br>It is cleared by writing 1 to the ESEIC bit in the DVP_ICLR register.<br>This feature is valid only when SM=1 is asserted. |
| Bit 1     | OVRIS    | 0x0         | ro   | Output data FIFO overrun interrupt status<br>0: No FIFO overrun interrupt generated<br>1: FIFO overrun interrupt generated<br>It is cleared by writing 1 to the OVRIC bit in the DVP_ICLR register.                                                                                                |
| Bit 0     | CFDIS    | 0x0         | ro   | Capture frame done interrupt status<br>0: A frame has not been captured<br>1: Capture frame done interrupt generated<br>It is cleared by writing 1 to the CFDIC bit in the DVP_ICLR register.                                                                                                      |

#### 27.8.6 DVP interrupt clear register (DVP\_ICLR)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                        |
|-----------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 5 | Reserved | 0x0000000   | resd | Kept at its default value.                                                                                                                                         |
| Bit 4     | HSIC     | 0x0         | wo   | Horizontal synchronization interrupt clear<br>Writing 1 to this bit clears the HSES bit in the DVP_ESTS register, and clears the HSIS bit in the DVPISTS register. |
| Bit 3     | VSIC     | 0x0         | wo   | Vertical synchronization interrupt clear<br>Writing 1 to this bit clears the VSES bit in the DVP_ESTS register, and clears the VSIS bit in the DVPISTS register.   |
| Bit 2     | ESEIC    | 0x0         | wo   | Embedded synchronization error interrupt clear                                                                                                                     |

|       |       |     |    |                                                                                                                                                                    |
|-------|-------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     |    | Writing 1 to this bit clears the ESEES bit in the DVP_ESTS register, and clears the ESEIS bit in the DVPISTS register.                                             |
| Bit 1 | OVRIC | 0x0 | wo | Output data FIFO overrun interrupt clear<br>Writing 1 to this bit clears the OVRES bit in the DVP_ESTS register, and clears the OVRIS bit in the DVPISTS register. |
| Bit 0 | CFDIC | 0x0 | wo | Capture frame done interrupt clear<br>Writing 1 to this bit clears the CFDES bit in the DVP_ESTS register, and clears the CFDIS bit in the DVPISTS register.       |

## 27.8.7 DVP embedded synchronization code register (DVP\_SCR)

| Bit        | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | FMEC | 0x00        | rw   | Frame end synchronization 4th code<br>Frame end delimiter code consists of four consecutive data:<br>All 1, all 0, all 0, FE4<br>Frame end delimiter 4 <sup>th</sup> code (FE4) is composed of FMEC.<br>In embedded synchronization mode, if the FMEC is programmed to 0xFF, the decoder performs embedded synchronization for any frame end delimiter.<br>All the undefined bytes other than FMSC, LNSC and LNEC are interpreted as frame end delimiter 4 <sup>th</sup> code FE4 |
| Bit 23: 16 | LNEC | 0x00        | rw   | Line end synchronization 4th code<br>The code consists of 4 consecutive data:<br>All 1, all 0, all 0 and LE4<br>Line end delimiter 4 <sup>th</sup> data (LE4) is composed of LNEC.                                                                                                                                                                                                                                                                                                |
| Bit 15: 8  | LNSC | 0x00        | rw   | Line start synchronization 4th code<br>The code consists of 4 consecutive data:<br>All 1, all 0, all 0 and LS4<br>Line start delimiter 4 <sup>th</sup> data (LS4) is composed of LNSC.                                                                                                                                                                                                                                                                                            |
| Bit 7: 0   | FMSC | 0x00        | rw   | Frame start synchronization 4th code<br>In embedded synchronization mode, if the FMSC and FMSU both are programmed to 0xFF, the decoder performs embedded synchronization for non-frame-start synchronization code.<br>The first occurrence of line start synchronization code after a Frame end code will be interpreted as a start of frame synchronization code.                                                                                                               |

## 27.8.8 DVP embedded synchronization unmask register (DVP\_SUR)

| Bit        | Name | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                              |
|------------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 24 | FMEU | 0x00        | rw   | Frame end synchronization code unmask<br>This field specifies the mask to be applied to the code of the frame end synchronization.<br>PDL=0, set bit N =0 in the FMEU, the bit N is masked<br>PDL=1, set bit N =0 in the FMEU, the bit N+2 is masked<br>PDL=2, set bit N =0 in the FMEU, the bit N+4 is masked<br>PDL=2, set bit N =0 in the FMEU, the bit N+6 is masked |
| Bit 23: 16 | LNEU | 0x00        | rw   | Line end synchronization code unmask<br>This field specifies the mask to be applied to the code of the line end synchronization.<br>PDL=0, set bit N =0 in the LNEU, the bit N is masked<br>PDL=1, set bit N =0 in the LNEU, the bit N+2 is masked<br>PDL=2, set bit N =0 in the LNEU, the bit N+4 is masked<br>PDL=2, set bit N =0 in the LNEU, the bit N+6 is masked   |
| Bit 15: 8  | LNSU | 0x00        | rw   | Line start synchronization code unmask<br>This field specifies the mask to be applied to the code of the line end synchronization.<br>PDL=0, set bit N =0 in the LNSU, the bit N is masked                                                                                                                                                                               |

|          |      |      |    |                                                                                                                                                                                                                                    |
|----------|------|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |      |      |    | PDL=1, set bit N =0 in the LNSU, the bit N+2 is masked<br>PDL=2, set bit N =0 in the LNSU, the bit N+4 is masked<br>PDL=2, set bit N =0 in the LNSU, the bit N+6 is masked                                                         |
| Bit 7: 0 | FMSU | 0x00 | rw | Frame start synchronization code unmask<br>This field specifies the mask to be applied to the code of the line end synchronization.                                                                                                |
|          |      |      |    | PDL=0, set bit N =0 in the FMSU, the bit N is masked<br>PDL=1, set bit N =0 in the FMSU, the bit N+2 is masked<br>PDL=2, set bit N =0 in the FMSU, the bit N+4 is masked<br>PDL=2, set bit N =0 in the FMSU, the bit N+6 is masked |

## 27.8.9 DVP crop window start register (DVP\_CWST)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                         |
|------------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 29 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                          |
| Bit 28: 16 | CVSTR    | 0x00        | rw   | Crop window vertical start line<br>This field specifies the start position of crop window in vertical axis. The first line data captured after the Frame start is line 0, the second line data captured is line 1, and so on.       |
| Bit 15: 14 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                          |
| Bit 13: 0  | CHSTR    | 0x00        | rw   | Crop window horizontal start pixel<br>This field specifies the start position of crop window in horizontal axis. The first pixel data captured after the Frame start is data 0, the second line data captured is data 1, and so on. |

## 27.8.10 DVP crop window size register (DVP\_CWSZ)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                        |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 30 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                         |
| Bit 29: 16 | CVNUM    | 0x00        | rw   | Crop window vertical line number minus one<br>This field specifies the number of lines of a crop window in vertical axis. CVNM1=N indicates that N+1 data has been cropped from the vertical axis.                 |
| Bit 15: 14 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                         |
| Bit 13: 0  | CHNUM    | 0x00        | rw   | Crop window horizontal pixel number minus one<br>This field specifies the number of pixel data of a crop window in horizontal axis. CHNM1=N indicates that N+1 pixel data has been cropped from the vertical axis. |

## 27.8.11 DVP data register (DVP\_DT)

| Bit       | Name | Reset value | Type | Description                                                               |
|-----------|------|-------------|------|---------------------------------------------------------------------------|
| Bit 31: 0 | DT   | 0x00000000  | ro   | Data Port<br>This register is used by the DMA controller to pick up data. |

## 27.8.12 DVP advanced control register (DVP\_ACTRL)

| Bit        | Name     | Reset value | Type | Description                                                                                                                                                                                                                              |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 18 | Reserved | 0x00        | resd | Kept at its default value.                                                                                                                                                                                                               |
| Bit 17     | VSEID    | 0x0         | rw   | Vertical synchronization event and interrupt definition<br>0: VSES and VEIS indicates frame end event and interrupt<br>1: VSES and VEIS indicates frame start event and interrupt                                                        |
| Bit 16     | HSEID    | 0x0         | rw   | Horizontal synchronization event and interrupt definition<br>0: HSES and HEIS indicates line end event and interrupt<br>1: HSES and HEIS indicates line start event and interrupt                                                        |
| Bit 15: 13 | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                               |
| Bit 12     | DMABT    | 0x0         | rw   | DMA burst transaction<br>This register works with EDMA's peripheral transfer configuration (PBURST)<br>0: DMA burst transaction disabled. The EDMA's peripheral transfer must be programmed as a single transfer (PBURST=0), or use DMA. |

|          |          |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|----------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          |     |      | 1: DMA burst transaction enabled. The EDMA's peripheral transfer must be programmed as INCR4 (PBURST=1). This configuration is enabled only when the EDMA is used for data transfer. If the DMA is used, this configuration must be disabled.                                                                                                                                                                                                                |
| Bit 11   | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 10   | IDUS     | 0x0 | rw   | Input data un-used setting<br>0: Unused data bit in the MSB<br>1: Unused data bit in the LSB                                                                                                                                                                                                                                                                                                                                                                 |
|          |          |     |      | Input data un-used bit number<br>0: No unused bits<br>1: 2-bit unused data<br>2: 4-bit unused data<br>3: 6-bit unused data                                                                                                                                                                                                                                                                                                                                   |
| Bit 9: 8 | IDUN     | 0x0 | rw   |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Bit 7    | Reserved | 0x0 | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 6    | EFDM     | 0x0 | rw   | Enhanced function data format management<br>0: Enhanced function data format management disabled<br>1: Enhanced function data format management enabled<br>Enhanced function data format management must be enabled before enabling the enhanced image scaling resize and monochrome image binarization.                                                                                                                                                     |
| Bit 5: 4 | EFDF     | 0x0 | rw   | Enhanced function data format<br>0: YUV422 (UYVY / VYUY) data format<br>1: YUV422 (YUYV / YYVU) data format<br>2: RGB565 and RGB555 data format<br>3: Y8 (Y only) data format<br>This configuration is valid when EFDM=1 is asserted.                                                                                                                                                                                                                        |
| Bit 3    | PCDES    | 0x0 | rw   | Basic pixel capture/drop extended selection<br>This register works with a basic pixel capture/drop selection (PCDS).<br>PCDS=0:<br>0: Capture the first pixel data and drop others<br>1: Capture the second pixel data and drop others<br>PCDS=1:<br>0: Capture the third pixel data and drop others<br>1: Capture the forth pixel data and drop others<br>This configuration is valid only when the basic pixel capture/drop control is enabled and PCDC=2. |
| Bit 2    | MIBE     | 0x0 | rw   | Monochrome image binarization enable<br>0: Monochrome image binarization disabled<br>1: Monochrome image binarization enabled<br>This configuration is valid only when EFDM=1 and EFDF is set based on CMOS video camera output format.                                                                                                                                                                                                                      |
| Bit 1    | EFRCE    | 0x0 | rw   | Enhanced frame rate control enable<br>0: Enhanced frame rate control disabled<br>1: Enhanced frame rate control enabled<br>This configuration is valid only when CFM=0 and basic frame rate control is disabled.                                                                                                                                                                                                                                             |
| Bit 0    | EISRE    | 0x0 | rw   | Enhanced image scaling resize enable<br>0: Enhanced image scaling resize disabled<br>1: Enhanced image scaling resize enabled<br>This configuration is valid only when PCDC=0 and LCDC=0.<br>This configuration works normally only when EFDM=1 and EFDT is set.                                                                                                                                                                                             |

## 27.8.13 DVP enhanced horizontal scaling factor register (DVP\_HSCF)

| Bit        | Name     | Reset value | Type | Description                                                                                                        |
|------------|----------|-------------|------|--------------------------------------------------------------------------------------------------------------------|
| Bit 30: 29 | Reserved | 0x0         | resd | Kept at its default value.                                                                                         |
| Bit 28: 16 | HSRTF    | 0x00        | rw   | Horizontal scaling resize target factor<br>When EISRE=1, this register must not be 0, or greater than HSRSF value. |
| Bit 15: 13 | Reserved | 0x0         | resd | Kept at its default value.                                                                                         |
| Bit 12: 0  | HSRSF    | 0x00        | rw   | Horizontal scaling resize source factor<br>When EISRE=1, this register must not be 0,                              |

## 27.8.14 DVP enhanced vertical scaling factor register (DVP\_VSCF)

| Bit        | Name     | Reset value | Type | Description                                                                                                      |
|------------|----------|-------------|------|------------------------------------------------------------------------------------------------------------------|
| Bit 30: 29 | Reserved | 0x0         | resd | Kept at its default value.                                                                                       |
| Bit 28: 16 | VSRTF    | 0x00        | rw   | Vertical scaling resize target factor<br>When EISRE=1, this register must not be 0, or greater than VSRSF value. |
| Bit 15: 13 | Reserved | 0x0         | resd | Kept at its default value.                                                                                       |
| Bit 12: 0  | VSRSF    | 0x00        | rw   | Vertical scaling resize source factor<br>When EISRE=1, this register must not be 0,                              |

## 27.8.15 DVP enhanced frame rate control factor register (DVP\_FRF)

| Bit        | Name     | Reset value | Type | Description                                                                                                         |
|------------|----------|-------------|------|---------------------------------------------------------------------------------------------------------------------|
| Bit 30: 13 | Reserved | 0x00000     | resd | Kept at its default value.                                                                                          |
| Bit 12: 8  | EFRCTF   | 0x00        | rw   | Enhanced frame rate control target factor<br>When EFRE=1, this register must not be 0, or greater than EFRSF value. |
| Bit 7: 5   | Reserved | 0x0         | resd | Kept at its default value.                                                                                          |
| Bit 4: 0   | EFRCSF   | 0x00        | rw   | Enhanced frame rate control source factor<br>When EFRCE=1, this register must not be 0                              |

## 27.8.16 DVP binarization threshold register (DVP\_BTH)

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                                 |
|-----------|----------|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 30: 8 | Reserved | 0x000000    | resd | Kept at its default value.                                                                                                                                                                                                                                  |
| Bit 7: 0  | MIBTHD   | 0x00        | rw   | Monochrome image binarization threshold<br>Monochrome image is binarized based on this threshold.<br>The value above the threshold is regarded as 1, while the value below the threshold is regarded as 0.<br>This configuration is valid only when MIBE=1. |

# 28 Qud-SPI interface (QSPI)

## 28.1 Introduction

The QSPI interface consists of a command-based slave port, an XIP port (direct address mapping access) and QSPI interface controller used for 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 AHB data port to access data in either PIO or DMA mode.

## 28.2 QSPI main features

- DMA handshake and CPU PIO modes
- SPI mode, dual/quad output mode, dual/quad I/O mode and DPI/QPI mode
- XIP port (direct address mapping read/write)
- XIP port prefetch function (2-channel read cache)
- 128-byte TxFIFO/RxFIFO depth
- Programmable divider
- Data encryption

Figure 28-1 Function block diagram



## 28.3 QSPI command slave port

### 28.3.1 QSPI command slave port

The QSPI has a command slave interface that contains register and data ports. The users can access registers or data ports using this interface. 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.

### 28.3.2 CPU PIO mode

The data port can be accessed in either PIO or DMA mode. The RxFIFO / TxFIFO registers (0x18) must be polled in PIO mode. When the RxFIFO is ready, the user can read or store the entire RxFIFO data. When the TxFIFO is ready, it can be written with the entire data. The polling state must be guaranteed in PIO mode.

### 28.3.3 DMA handshake mode

The DMA mode can also be used 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 28-2 DMA handshake mode



### 28.3.4 XIP port (direct address mapping 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, only 0x10 register can be used 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.

### 28.3.5 XIP port prefetch

The XIP port supports read prefetch with 2-channel read cache.

### 28.3.6 SPI device operation

#### Command phase

The QSPI operations are conducted through commands, which are used to indicate the intent of the operation and SPI operating mode (multiple-line communication).

Note: the command phase can be set to 1 or 2 bytes. However, in 2-byte mode, it sends two repeated 1-byte commands. Only 1-byte register is used to store command words.

#### Address phase

The address phase is required to perform read, write, and erase operations on the memory.

In the address phase, the address phase can be from 0 to 4byte in length; In XIP mode, the length of the address phase can be optional 3byte or 4byte.

#### Dummy-cycles phase

It is used to allow the to-be-read device the time to prepare for the subsequent to-be-read data. XIP and command mode must be configured through DUM2 and XIPR\_DUM2, respectively. Besides, the write timing of XIP mode also reserves programmable dummy cycles, which is usually configured to 0 through the XIPW\_DUM2 register.

#### Data phase

It is used as input when reading memory device data/status registers, and as an output when writing the memory device.

#### Serial (1-1-1) mode

The host controller supports a SPI protocol (mode 0 and mode 3). The command queue register must be programmed according to SPI device specification. Refer to Figure 28-3 and Figure 28-10 for more information on how to program a command queue.

To execute a write enable command, set instruction code to 06h, write enable, and set instruction length

to 1. Refer to Figure 28-3 for details.

Figure 28-3 Write enable



To execute page programming command, set instruction code to 02h, address register, address size, write enable and set instruction length to 1.

Figure 28-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 28-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 28-6 Data read



### Dual (1-1-2) mode

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 28-7 Quick read dual output command



### Dual I/O (1-2-2) mode

To execute a quick read dual I/O command, set code/ length, address/address size, enable enhanced performance mode/code and dual I/O operation commands. Refer to Figure 28-8 for details.

Figure 28-8 Quick read dual-wire I/O command



### Quad (1-1-4) mode

To execute a quick read quad command, set instruction code/length, address/address size, enable second dummy period and enable quad mode. Refer to Figure 28-9 for more information.

Figure 28-9 Quad read command



#### Quad I/O (1-4-4) mode

To execute a quick read quad I/O command, set instruction code/length, address/address size, the second dummy period, enable performance enhancement mode and enable quad I/O mode. Refer to Figure 28-10 for more information.

Figure 28-10 Quick read quad I/O command



If dual DPI (2-2-2) mode is to be used, it is necessary to set code/length, address/address length, the second dummy cycle and operation command of dual DPI mode. For details, refer to the figure below.

Figure 28-11 Dual DPI command



If quad DPI (4-4-4) mode is to be used, it is necessary to set code/length, address/address length, the second dummy cycle and operation command of quad DPI mode. For details, refer to the figure below.

Figure 28-12 Dual DPI command



#### XIP read/write D mode

If XIP read/write D mode is to be used, it is necessary to set code/length, address/address length, the second dummy cycle, select serial/two-line/two-line IO/four-line/four-line IO or DPI/QPI mode, and to set read/write D mode and D mode upper limit counter.

When XIP port is reading or writing back-to-back addresses, it will keep reading or writing until the higher threshold is reached or the address becomes discontinuous.

When reading,  $N(\text{byte}) = \text{XIPR\_DCNT} * 4$ ; when writing,  $N(\text{byte}) = \text{XIPW\_DCNT} * 4$ .

For more details, refer to the figure below.



### XIP read/write T mode

If XIP read/write T mode is to be used, it is necessary to set code/length, address/address length, the second dummy cycle, select serial/two-line/two-line IO/four-line/four-line IO or DPI/QPI mode, and to set read/write T mode and T mode upper limit counter.

When XIP port is reading or writing back-to-back addresses at intervals, it will disable CLK wait after reading or writing data. If the wait duration is longer than the threshold or when the next address is discontinuous, read/write operations stops.

When reading,  $T(\text{cycle}) = \text{XIPR\_TCNT}$ ; when writing,  $T(\text{cycle}) = \text{XIPW\_TCNT}$ .

For more details, refer to the figure below.



## 28.4 QSPI registers

These registers must be accessed by bytes (8-bit), half-words (16-bit) or words (32-bit).

Table 28-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  |

### 28.4.1 Command word 0 (CMD\_W0)

No-wait states, assessable by bytes, half-words and words.

| Bit       | Name   | Reset value | Type | Description                                                                                                                                                                |
|-----------|--------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | SPIADR | 0x0         | rw   | SPI Flash address<br>This register defines the values of SPI Flash addresses, and sends them to SPI Flash. The address byte is based on the bit [2: 0] of CMD_W1 register. |

### 28.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 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>                                                                                                                                                                                                                                                                                                                                                                      |

---

### 28.4.3 Command word 2 (CMD\_W2)

No-wait states, accessible 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> |

---

### 28.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 mode (1-1-2)<br/>           010: Quad mode (1-1-4)<br/>           011: Dual 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 is enabled.<br/>           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.                                                                                                                                                                                                                                                                                                                                                                                                                    |

## 28.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 Abort event occurs, this bit must be written (This bit is automatically cleared to 0).<br>0: No effect<br>1: Enabled                                                 |
| 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, sck_out is low in idle state, with data capture on the first edge<br>1: For mode 3, sck_out is high in idle state, with data capture 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 |

## 28.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>When this bit is set, it indicates the following:<br>1: RxFIFO full<br>2: The remaining data in the RxFIFO is less than the depth of RxFIFO, but it is the last data. |
| Bit 0     | TXFIFORDY | 0x1         | ro   | TxFIFO ready status<br>When the TxFIFO is set, it indicates that the TxFIFO will get empty so that data can be transmitted into it until it becomes full.                                    |

## 28.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. |

|            |             |      |      |                                                                                                                                            |
|------------|-------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------|
|            |             |      |      | 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. |
| Bit 13: 12 | RXFIFO THOD | 0x0  | rw   | The trigger value is the data in the RxFIFO.<br>00: 8 WORD<br>01: 16 WORD<br>10: 24 WORD<br>11: Reserved                                   |
| Bit 11: 10 | Reserved    | 0x0  | resd | Kept at its default value.                                                                                                                 |
|            |             |      |      | 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. |
| Bit 9: 8   | TXFIFO THOD | 0x0  | rw   | The trigger value is the data in the TxFIFO.<br>00: 8 WORD<br>01: 16 WORD<br>10: 24 WORD<br>11: Reserved                                   |
| Bit 7: 2   | Reserved    | 0x00 | resd | Kept at its default value.                                                                                                                 |
| Bit 1      | CMDIE       | 0x0  | rw   | Command complete Interrupt enable<br>0: Command complete Interrupt disabled<br>1: Command complete Interrupt enabled                       |
| Bit 0      | DMAEN       | 0x0  | rw   | DMA enable<br>Note: This bit must be disabled before moving from command-based slave port to XIP port.                                     |

#### 28.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>Set at the end of a command. |

#### 28.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   | SPI Read status<br>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. |

#### 28.4.10 Flash size register (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. |

## 28.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 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   | 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 |

## 28.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 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 | <p>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</p> |
|----------|-----------|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## 28.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   | <p>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.</p> |
| Bit 30: 24 | XIPW_TCNT | 0x0F        | rw   | <p>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.</p>                                                                                                                                                                                                                                                                                                        |
| Bit 23: 22 | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 21: 16 | XIPW_DCNT | 0x01        | rw   | <p>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.</p>                                                                                                                                                                                                                                                                                      |
| Bit 15     | XIPR_SEL  | 0x0         | rw   | <p>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.</p>      |
| Bit 14: 8  | XIPR_TCNT | 0x0F        | rw   | <p>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.</p>                                                                                                                                                                                                                                                                                                        |
| Bit 7: 6   | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 5: 0   | XIPR_DCNT | 0x01        | rw   | <p>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.</p>                                                                                                                                                                                                                                                                                      |

## 28.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 000  | resd | Kept at its default value.                                                                                                                        |
| Bit 3     | CSTS     | 0x0         | r    | Cache Status<br>0: Cache verified<br>1: Cache failed                                                                                              |
| Bit 2: 1  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                        |
| Bit 0     | BYPASSC  | 0x0         | rw   | Bypass Cache Function<br>When this bit is set, the high-speed cache feature is deactivated, and all read transfers do not check high-speed cache. |

## 28.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 000  | 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: 6  | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                            |
| Bit 0     | ISPD     | 0x00        | rw   | Input sampling phase delay<br>When ISPC is set, this bit setting is taken into account.                                                                                                                                               |

## 28.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. |

## 28.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. |

# 29 EDMA controller (EDMA)

## 29.1 Introduction

Enhanced direct memory access (EDMA) controller is designed for 32-bit MCU applications with the goal of enhancing system performance and reducing the generation of interrupts.

This controller offers 8 DMA channels to guarantee data transfers between peripheral-to-memory, memory-to-peripheral, and memory-to-memory.

## 29.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
- Two AHB main interfaces for data transfer
- Support 8 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
- Programmable chain transmission
- Programmable 2D transfer
- Support multiplexer

Figure 29-1 Block diagram



## 29.3 Functional overview

### 29.3.1 Flow configuration

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

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

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

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

#### 3. Configure the amount of data to be transferred in the DMA\_CxDTCNT 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\_CxCTRL register

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

- **Channel select (CHSEL)**

Each of the streams can be selected up to 8 possible channel requests

- **Channel priority (SPL)**

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

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

- **Data transfer direction (DTD)**

Memory-to-peripheral (M2P), peripheral-to-memory (P2M) or memory-to-memory (M2M)

In M2M mode, circular mode, dual memory mode and direct mode cannot be used.

- **Address incremented mode (PINCM/MINCM)**

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

- **Data transfer mode (PBURST/MBURST)**

Single transfer or burst transfer.

In non-incrementing mode, burst transfers of 4, 8 or 16 beats are translated into 4, 8 or 16 single transfers.

In direct mode, PBURST and MBURST bits are forced to 0 (single transfer mode)

- **Peripheral flow control (PFCTRL)**

If PFCTRL = 1 (peripheral flow control is used), the value of the DMA\_SxDTCNT register is forced to 0xFFFF. The dma\_ch\_lt signal of the peripherals indicates the completion of data transfer. The M2M mode and circular mode cannot be used in Peripheral Flow Control.

- **Circular mode (LM)**

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

- **Dual memory mode (DMM)**

When the flow is configured in dual memory mode, the hardware will automatically enable circular mode. Two memory pointers (DMA\_SxM0ADR/ DMA\_SxM1ADR) are available in dual memory flow. The CM bit indicates which one of the memory pointers is being used. The software is allowed to process another memory while the DMA is filling up or using the second memory.

#### 5. FIFO settings through the DMA\_SxFCTRL register

This includes FIFO threshold value select, direct mode disable and FIFO error interrupt enable bit.

##### FIFO threshold select (FTHSEL)

1/4, 2/4, 3/4 and full FIFO threshold values are available for selection. This bit is applicable to the non-direct mode only.

##### FIFO mode (FEN)

Direct mode (FEN = 0) can be used only in P2M or M2P mode, and the transfer width of peripherals and memories must be equal (MWIDHT = PWIDHT), and single transfer mode is enabled (PBURST = MBURST = 0). This bit (FEN) will be forced to 1 in M2M mode.

## 6. Enable DMA transfer through the SEN bit in the DMA\_SxCTRL register

### 29.3.2 Channel selection and synchronizer

The clocks between a peripheral and DMA may be asynchronous. The user can choose whether the synchronizer of the `dma_chx_req` is needed.

Figure 29-2 shows the block diagram of channel selection and synchronizer.

Figure 29-2 Channel select and synchronizer



### 29.3.3 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 or burst) until the signal is acknowledged. After the completion of peripheral transmission, the DMA controller sends an 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.

In non-incrementing mode (`PINCM = 0`), burst transfers 4, 8 or 16 beats are translated into 4, 8 or 16 single transfers. These data will be transferred by the main peripheral controller in a request/acknowledge group.

In peripheral flow control mode (`PFCTRL = 1`), only a single transfer is present in a request/ acknowledgement group.

### 29.3.4 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 29-3 shows the behavior between DMA request/acknowledge and arbiter. Since there is only one single or burst transfer in a request/acknowledge group, it works in the same way as a re-arbitration mechanism. Thus the main peripheral controller will re-arbitrate to serve other channels each time a channel completes a single or burst transfer according to the priority defined by the main controller.

Figure 29-3 Re-arbitrate after Request/Acknowledge



In non-incrementing mode (PINCM = 0 or MINCM = 0), burst transfers of 4, 8 or 16 beats are translated into 4, 8 or 16 single transfers. In this case, the main controller will transfer all data before re-arbitration.

### 29.3.5 Programmable data transfer width

Transfer width of the source data and destination data is programmable through the PWIDTH and MWIDTH bits in the DMA\_CxCTRL register. When PWIDTH is not equal to MWIDTH, a packing and unpacking mechanism is performed. When the transfer size of the source data is less than that of the destination data, the data is packed in FIFO before sending to the destination. On the contrary, if the transfer size of the source data is greater than that of the destination data, the data is unpacked before sending to the destination.

PWIDTH, MWIDTH and CNT must be configured correctly to ensure complete data transfer.

$$\text{CNT} = (\text{MWIDTH}/\text{PWIDTH}) \times N$$

- MWIDTH and PWIDTH stand for data transfer size = 1 (byte), 2 (half-words) or 4 (words)
- CNT and N are positive integers.

Figure 29-4 Example of packing mechanism



Figure 29-5 Example of unpacking mechanism



Figure 29-6 Example of PINCOS



### 29.3.6 FIFO and threshold

Each stream has its dedicated 4-word FIFO that is programmed with different threshold (1/4, 1/2, 3/4 or full). The FTHSEL bit must match the MBURST bit; otherwise a FIFO error (FERR) is generated while enabling a stream, causing that a stream is automatically disabled.

$$\text{FTHSEL} \times 4 = \text{MBURST} \times \text{MWIDHT} \times M$$

- FTHSEL (FIFO threshold) = 1 (1/4), 2 (1/2), 3 (3/4) or 4 (Full)
- MBURST (data transfer size) = 1 (single) or 4, 8 or 16 burst
- MWIDHT (data transfer width) = 1 (byte), 2 (half-word) or 4 (word)
- M is a positive integer

Additionally, the MBURST/PBURST and MWIDHT/PWIDTH bits must match the CNT bit for full data transfers.

$$CNT = PBURST \times PWIDTH \times N = MBURST \times MWIDTH \times M$$

- MBURST/PBURST (data transfer size) = 1 (single) or 4, 8 or 16 burst
- MWIDTH/PWIDTH (data transfer width) = 1 (byte), 2 (half-word) or 4 (word)
- M, N, CNT are positive integers

If mismatch, when the remaining data is less than the MBURST/PBURST bits, they are transmitted by hardware in a single mode, and set the FDTF bit after the completion of refresh. If the remaining data is less than the MWIDTH/PWIDTH, data are still transmitted based on the width programmed in the MWIDTH bit.

### 29.3.7 Linked table transfer mechanism

Using this mechanism, it is possible to link several different transfers to strengthen DMA processing capabilities. Each transfer data can be stored in a descriptor by software, and the DMA loads the descriptor from the main memory.

To enable a linked table transfer, set the SxLLSEN (where n is a stream number) bit in the DMA\_LLCTRL register and the local descriptor memory base address, and prepare LDM or main memory descriptor. Then, the user can continue to set DMA\_SxDTCNT=0, write the descriptor address to the DMA\_SxLLP and enable a stream.

After enabling a stream, the memory controller in DMA issues a few AHB commands to load the descriptor from the main memory.

Figure 29-7 gives the descriptor format. After loading descriptors (that is, CTRL and CNT, PADDR and M0ADDR), the DMA uses these bits for data transfers. When a descriptor transaction is completed (CNT becomes 0), if the current LLP is not equal to zero, the DMA continues to load the next descriptor. If the current LLP is zero, it means that the current descriptor is the last one, and the DMA stops loading a new one. At this point, a transfer completed interrupt (FDTF bit) is generated to mark the completion of a linked table transfer. It should be noted that the TC is generated at the last descriptor.

Figure 29-7 Descriptor format

|            |        | bit offset   |        |     |        |        |        |        |      |       |     |             |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------|--------|--------------|--------|-----|--------|--------|--------|--------|------|-------|-----|-------------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|            |        | 31           | 30     | 29  | 28     | 27     | 26     | 25     | 24   | 23    | 22  | 21          | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CTRL & CNT |        | FEN          | PINCOS | SPL | MBURST | PBURST | MWIDTH | PWIDTH | MNCM | PINCM | DTD | DTCNT[15:0] |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +4         | PADDR  | PADDR[31:0]  |        |     |        |        |        |        |      |       |     |             |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +8         | M0ADDR | M0ADDR[31:0] |        |     |        |        |        |        |      |       |     |             |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +C         | LLP    | LLP[31:0]    |        |     |        |        |        |        |      |       |     |             |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 29-8 Linked list pointers



### 29.3.8 2D transfer mechanism

The 2-dimensional (2D) transfer mechanism makes it easier to block data like images. The DMA controller offers four types of configurations for 2D transfers.

- XCNT bit in DMA\_Sx2DCNT: Data count to be transmitted before jumping to the next stride
- YCOUTNT bit in DMA\_Sx2DCNT: Iteration count
- SRCSTD bit in DMA\_Sx2DStride: Source stride value. This value should be added or subtracted before source iteration
- DSTSTD bit in DMA\_Sx2DStride: Destination stride value. This value should be added or subtracted before destination iteration.

Example of a 2D transfer:

| Source stride<br>(byte address) | Destination stride<br>(byte address) | XCNT | YCNT |
|---------------------------------|--------------------------------------|------|------|
| 0x20                            | 0x10                                 | 0x4  | 0x8  |

As shown in Figure 29-9, the user can read 2D-block data from the source memory. The XCNT is a 4-beat data (4 beat means four words=16 bytes) that is read by DMA before iteration. After reading data from the word address 0x0 to 0x3 (byte address from 0x0 to 0xF), the next read address is the source address plus source stride ( $0x0 + 0x20 = 0x20$  byte address=0x8 word address). Therefore, the DMA can perform the second iteration and read four data beats from the slave word address 0x8, 0x9, 0xA and 0xB (byte address ranging from 0x20 to 0x2F). The YCOUTNT bit has up to 8 iterations, which is equal to 0x8. When both the YCOUTNT and XCNT bits become 0, it indicates that a total of 32-word data (8 iterations \*4 beats) have been read from the source memory.

Figure 29-9 Example of a 2D transfer (source side is managed by a peripheral controller)



Figure 29-10 shows how to load data in source memory to destination memory. The only difference between them is the stride value. After the DMA writes 4-word data from 0x0 to 0x3, the next write address is the destination address plus the destination stride ( $0x0 + 0x10 = 0x10$  byte address = 0x4 word address). Then the DMA controller can continue a second iteration to write four beats in the word address ranging from 0x4 to 0x7 (byte address from 0x10 to 0x1F). When both the YCOTNT and XCOTNT become zero, it indicates that all 32-word data (8 iterations\*4 beats) have been written to the destination memory.

Figure 29-10 Example of a 2D transfer (destination side is managed by a memory controller)



## Limits on 2D transfers

- Support M2M transfer only
- PWIDTH and MISZE must be set to 2 (word)
- Source and destination stride values must be word-aligned
- Source and destination stride values must be two's complement
- PINCM and MINCM bits must be set to 1 (incremented mode)
- PFCTRL bit must be set to 0
- PINCOS bit must be set to 0
- Circular and dual buffer mode are not supported
- Linked table transfer is not supported

### 29.3.9 Errors

Table 29-1 DMA error events

## Error events

|                                                                                                   |                                                                                                                                      |
|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Transfer error                                                                                    | AHB response error during DMA read/write                                                                                             |
|                                                                                                   | Write access to the current destination memory address register in dual buffer mode                                                  |
| FIFO error                                                                                        | FIFO overrun in P2M transfer or FIFO underrun in M2P transfer                                                                        |
|                                                                                                   | Stream enabled when FIFO threshold bit does not match memory burst size bit                                                          |
| The total transfer count is not a multiple of that of PBURST bit in peripheral flow control mode. |                                                                                                                                      |
| Direct error                                                                                      | In the case of FEN = 1 and MINCM = 0, a DMA request is generated before the previous data have been completely transmitted to memory |

## 29.3.10 Interrupts

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

Table 29-2 DMA interrupts

| Interrupt events  | Event flag | Clear control bit | Enable control bit |
|-------------------|------------|-------------------|--------------------|
| Half-transfer     | FDTF       | FDTFC             | FDTIEN             |
| Transfer complete | HDTF       | HDTFC             | HDTIEN             |
| Transfer error    | DTERRF     | DTERRFC           | DTERRIEN           |
| FIFO error        | FERRF      | FERRFC            | FERRIEN            |
| Direct mode error | DMERRF     | DMERRFC           | DMERRIEN           |

## 29.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.

EXINT LINE is used as the trigger input for request generators and the synchronized input for requests.

### 29.4.1 DMAMUX functional 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\_MUXGxCTR 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 is used in the DMA\_MUXGxCTRL register 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 is set in the DMA\_MUXCxCTRL register, the programmable request counter (REQCNT) is used to generate a request output and event output.

Figure 29-11 DMAMUX block diagram



Table 29-3 EDMA flexible request mapping

| DMAMUX request | Source        | DMAMUX request | Source        | DMAMUX request | Source        | DMAMUX request | Source      |
|----------------|---------------|----------------|---------------|----------------|---------------|----------------|-------------|
| 1              | DMA_MUXREQG1  | 33             | UART5_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             | ADC2          | 68             | TMR4_CH2      | 100            | reserved    |
| 5              | ADC1          | 37             | ADC3          | 69             | TMR4_CH3      | 101            | reserved    |
| 6              | DAC1          | 38             | reserved      | 70             | TMR4_CH4      | 102            | reserved    |
| 7              | reserved      | 39             | SDIO1         | 71             | TMR4_OVERFLOW | 103            | SDIO2       |
| 8              | TMR6_OVERFLOW | 40             | QSPI1         | 72             | TMR5_CH1      | 104            | QSPI2       |
| 9              | TMR7_OVERFLOW | 41             | DAC2          | 73             | TMR5_CH2      | 105            | DVP         |
| 10             | SPI1_RX       | 42             | TMR1_CH1      | 74             | TMR5_CH3      | 106            | SPI4_RX     |
| 11             | SPI1_TX       | 43             | TMR1_CH2      | 75             | TMR5_CH4      | 107            | SPI4_TX     |
| 12             | SPI2_RX       | 44             | TMR1_CH3      | 76             | TMR5_OVERFLOW | 108            | reserved    |
| 13             | SPI2_TX       | 45             | TMR1_CH4      | 77             | TMR5_TRIG     | 109            | reserved    |
| 14             | SPI3_RX       | 46             | TMR1_OVERFLOW | 78             | reserved      | 110            | I2S2_EXT_RX |
| 15             | SPI3_TX       | 47             | TMR1_TRIG     | 79             | reserved      | 111            | I2S2_EXT_TX |
| 16             | I2C1_RX       | 48             | TMR1_HALL     | 80             | reserved      | 112            | I2S3_EXT_RX |
| 17             | I2C1_TX       | 49             | TMR8_CH1      | 81             | reserved      | 113            | I2S3_EXT_TX |
| 18             | I2C2_RX       | 50             | TMR8_CH2      | 82             | reserved      | 114            | USART6_RX   |
| 19             | I2C2_TX       | 51             | TMR8_CH3      | 83             | reserved      | 115            | USART6_TX   |
| 20             | I2C3_RX       | 52             | TMR8_CH4      | 84             | reserved      | 116            | UART7_RX    |

|    |           |    |               |    |                |     |           |
|----|-----------|----|---------------|----|----------------|-----|-----------|
| 21 | I2C3_TX   | 53 | TMR8_OVERFLOW | 85 | reserved       | 117 | UART7_TX  |
| 22 | reserved  | 54 | TMR8_TRIG     | 86 | TMR20_CH1      | 118 | UART8_RX  |
| 23 | reserved  | 55 | TMR8_HALL     | 87 | TMR20_CH2      | 119 | UART8_TX  |
| 24 | USART1_RX | 56 | TMR2_CH1      | 88 | TMR20_CH3      | 120 | reserved  |
| 25 | USART1_TX | 57 | TMR2_CH2      | 89 | TMR20_CH4      | 121 | reserved  |
| 26 | USART2_RX | 58 | TMR2_CH3      | 90 | TMR20_OVERFLOW | 122 | reserved  |
| 27 | USART2_TX | 59 | TMR2_CH4      | 91 | reserved       | 123 | reserved  |
| 28 | USART3_RX | 60 | TMR2_OVERFLOW | 92 | reserved       | 124 | reserved  |
| 29 | USART3_TX | 61 | TMR3_CH1      | 93 | TMR20_TRIG     | 125 | reserved  |
| 30 | UART4_RX  | 62 | TMR3_CH2      | 94 | TMR20_HALL     | 126 | TMR2_TRIG |
| 31 | UART4_TX  | 63 | TMR3_CH3      | 95 | reserved       | 127 | TMR4_TRIG |
| 32 | UART5_RX  | 64 | TMR3_CH4      | 96 | reserved       |     |           |

Table 29-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 | 29         | reserved |
| 6          | exint_gpio[6] | 14         | exint_gpio[14] | 22         | DMA_MUXevt7 | 30         | reserved |
| 7          | exint_gpio[7] | 15         | exint_gpio[15] | 23         | DMA_MUXevt8 | 31         | reserved |

## 29.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 the SYNCOVFCx bit in the DMA\_MUXSYNCCLR register. An interrupt will be generated if the interrupt enable bit SYNCOVIEN is set in the DMA\_MUXSxCTRL register.

Figure 29-12 DMAMUX synchronized mode



Figure 29-13 DMAMUX event generation



## 29.5 EDMA registers

Table 29-5 shows DMA register map and reset values.

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

Table 29-5 BPR register map and reset values

| Register      | Offset | Reset value |
|---------------|--------|-------------|
| EDMA_STS1     | 0x00   | 0x0000 0000 |
| EDMA_STS2     | 0x04   | 0x0000 0000 |
| EDMA_CLR1     | 0x08   | 0x0000 0000 |
| EDMA_CLR2     | 0x0c   | 0x0000 0000 |
| EDMA_S1CTRL   | 0x10   | 0x0000 0000 |
| EDMA_S1DTCNT  | 0x14   | 0x0000 0000 |
| EDMA_S1PADDR  | 0x18   | 0x0000 0000 |
| EDMA_S1M0ADDR | 0x1c   | 0x0000 0000 |
| EDMA_S1M1ADDR | 0x20   | 0x0000 0000 |
| EDMA_S1FCTRL  | 0x24   | 0x0000 0000 |
| EDMA_S2CTRL   | 0x28   | 0x0000 0000 |
| EDMA_S2DTCNT  | 0x2c   | 0x0000 0000 |
| EDMA_S2PADDR  | 0x30   | 0x0000 0000 |
| EDMA_S2M0ADDR | 0x34   | 0x0000 0000 |
| EDMA_S2M1ADDR | 0x38   | 0x0000 0000 |
| EDMA_S2FCTRL  | 0x3c   | 0x0000 0000 |
| EDMA_S3CTRL   | 0x40   | 0x0000 0000 |
| EDMA_S3DTCNT  | 0x44   | 0x0000 0000 |
| EDMA_S3PADDR  | 0x48   | 0x0000 0000 |
| EDMA_S3M0ADDR | 0x4c   | 0x0000 0000 |
| EDMA_S3M1ADDR | 0x50   | 0x0000 0000 |
| EDMA_S3FCTRL  | 0x54   | 0x0000 0000 |
| EDMA_S4CTRL   | 0x58   | 0x0000 0000 |
| EDMA_S4DTCNT  | 0x5c   | 0x0000 0000 |
| EDMA_S4PADDR  | 0x60   | 0x0000 0000 |
| EDMA_S4M0ADDR | 0x64   | 0x0000 0000 |
| EDMA_S4M1ADDR | 0x68   | 0x0000 0000 |
| EDMA_S4FCTRL  | 0x6c   | 0x0000 0000 |
| EDMA_S5CTRL   | 0x70   | 0x0000 0000 |
| EDMA_S5DTCNT  | 0x74   | 0x0000 0000 |
| EDMA_S5PADDR  | 0x78   | 0x0000 0000 |
| EDMA_S5M0ADDR | 0x7c   | 0x0000 0000 |
| EDMA_S5M1ADDR | 0x80   | 0x0000 0000 |
| EDMA_S5FCTRL  | 0x84   | 0x0000 0000 |
| EDMA_S6CTRL   | 0x88   | 0x0000 0000 |
| EDMA_S6DTCNT  | 0x8c   | 0x0000 0000 |

|               |       |             |
|---------------|-------|-------------|
| EDMA_S6PADDR  | 0x90  | 0x0000 0000 |
| EDMA_S6M0ADDR | 0x94  | 0x0000 0000 |
| EDMA_S6M1ADDR | 0x98  | 0x0000 0000 |
| EDMA_S6FCTRL  | 0x9c  | 0x0000 0000 |
| EDMA_S7CTRL   | 0xa0  | 0x0000 0000 |
| EDMA_S7DTCNT  | 0xa4  | 0x0000 0000 |
| EDMA_S7PADDR  | 0xa8  | 0x0000 0000 |
| EDMA_S7M0ADDR | 0xac  | 0x0000 0000 |
| EDMA_S7M1ADDR | 0xb0  | 0x0000 0000 |
| EDMA_S7FCTRL  | 0xb4  | 0x0000 0000 |
| EDMA_S8CTRL   | 0xb8  | 0x0000 0000 |
| EDMA_S8DTCNT  | 0xbc  | 0x0000 0000 |
| EDMA_S8PADDR  | 0xc0  | 0x0000 0000 |
| EDMA_S8M0ADDR | 0xc4  | 0x0000 0000 |
| EDMA_S8M1ADDR | 0xc8  | 0x0000 0000 |
| EDMA_S8FCTRL  | 0xcc  | 0x0000 0000 |
| EDMA_LLCTRL   | 0xd0  | 0x0000 0000 |
| EDMA_S1LLP    | 0xd4  | 0x0000 0000 |
| EDMA_S2LLP    | 0xd8  | 0x0000 0000 |
| EDMA_S3LLP    | 0xdc  | 0x0000 0000 |
| EDMA_S4LLP    | 0xe0  | 0x0000 0000 |
| EDMA_S5LLP    | 0xe4  | 0x0000 0000 |
| EDMA_S6LLP    | 0xe8  | 0x0000 0000 |
| EDMA_S7LLP    | 0xec  | 0x0000 0000 |
| EDMA_S8LLP    | 0xf0  | 0x0000 0000 |
| EDMA_S2DCTRL  | 0xf4  | 0x0000 0000 |
| EDMA_S12DCNT  | 0xf8  | 0x0000 0000 |
| EDMA_S1STRIDE | 0xfc  | 0x0000 0000 |
| EDMA_S22DCNT  | 0x100 | 0x0000 0000 |
| EDMA_S2STRIDE | 0x104 | 0x0000 0000 |
| EDMA_S32DCNT  | 0x108 | 0x0000 0000 |
| EDMA_S3STRIDE | 0x10c | 0x0000 0000 |
| EDMA_S42DCNT  | 0x110 | 0x0000 0000 |
| EDMA_S4STRIDE | 0x114 | 0x0000 0000 |
| EDMA_S52DCNT  | 0x118 | 0x0000 0000 |
| EDMA_S5STRIDE | 0x11c | 0x0000 0000 |
| EDMA_S62DCNT  | 0x120 | 0x0000 0000 |
| EDMA_S6STRIDE | 0x124 | 0x0000 0000 |
| EDMA_S72DCNT  | 0x128 | 0x0000 0000 |
| EDMA_S7STRIDE | 0x12c | 0x0000 0000 |
| EDMA_S82DCNT  | 0x130 | 0x0000 0000 |

|                  |       |             |
|------------------|-------|-------------|
| EDMA_S8STRIDE    | 0x134 | 0x0000 0000 |
| EDMA_SYNCEN      | 0x138 | 0x0000 0000 |
| EDMA_MUXSEL      | 0x13c | 0x0000 0000 |
| EDMA_MUXS1CTRL   | 0x140 | 0x0000 0000 |
| EDMA_MUXS2TRL    | 0x144 | 0x0000 0000 |
| EDMA_MUXS3CTRL   | 0x148 | 0x0000 0000 |
| EDMA_MUXS4CTRL   | 0x14c | 0x0000 0000 |
| EDMA_MUXS5CTRL   | 0x150 | 0x0000 0000 |
| EDMA_MUXS6CTRL   | 0x154 | 0x0000 0000 |
| EDMA_MUXS7CTRL   | 0x158 | 0x0000 0000 |
| EDMA_MUXS8CTRL   | 0x15c | 0x0000 0000 |
| EDMA_MUXG1CTRL   | 0x160 | 0x0000 0000 |
| EDMA_MUXG2CTRL   | 0x164 | 0x0000 0000 |
| EDMA_MUXG3CTRL   | 0x168 | 0x0000 0000 |
| EDMA_MUXG4CTRL   | 0x16c | 0x0000 0000 |
| EDMA_MUXSYNCSTS  | 0x170 | 0x0000 0000 |
| EDMA_MUXSYNCCCLR | 0x174 | 0x0000 0000 |
| EDMA_MUXGSTS     | 0x178 | 0x0000 0000 |
| EDMA_MUXGCLR     | 0x17c | 0x0000 0000 |

### 29.5.1 DMA status register 1 (DMA\_STS1)

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     | FDTF4    | 0x0         | ro   | Stream4 full data transfer complete interrupt flag |
| Bit 26     | HDTF4    | 0x0         | ro   | Stream4 half data transfer complete interrupt flag |
| Bit 25     | DTERRF4  | 0x0         | ro   | Stream4 transfer error interrupt flag              |
| Bit 24     | DMERRF4  | 0x0         | ro   | Stream4 direct mode error interrupt flag           |
| Bit 23     | Reserved | 0x0         | ro   | Kept at its default value.                         |
| Bit 22     | FERRF4   | 0x0         | ro   | Stream4 fifo error interrupt flag                  |
| Bit 21     | FDTF3    | 0x0         | ro   | Stream3 full data transfer complete interrupt flag |
| Bit 20     | HDTF3    | 0x0         | ro   | Stream3 half data transfer complete interrupt flag |
| Bit 19     | DTERRF3  | 0x0         | ro   | Stream3 transfer error interrupt flag              |
| Bit 18     | DMERRF3  | 0x0         | ro   | Stream3 direct mode error interrupt flag           |
| Bit 17     | Reserved | 0x0         | ro   | Kept at its default value.                         |
| Bit 16     | FERRF3   | 0x0         | ro   | Stream3 fifo error interrupt flag                  |
| Bit 15: 12 | Reserved | 0x0         | resd | Kept at its default value.                         |

|        |          |     |    |                                                    |
|--------|----------|-----|----|----------------------------------------------------|
| Bit 11 | FDTF2    | 0x0 | ro | Stream2 full data transfer complete interrupt flag |
| Bit 10 | HDTF2    | 0x0 | ro | Stream2 half transfer complete interrupt flag      |
| Bit 9  | DTERRF2  | 0x0 | ro | Stream2 transfer error interrupt flag              |
| Bit 8  | DMERRF2  | 0x0 | ro | Stream2 direct mode error interrupt flag           |
| Bit 7  | Reserved | 0x0 | ro | Kept at its default value.                         |
| Bit 6  | FERRF2   | 0x0 | ro | Stream2 fifo error interrupt flag                  |
| Bit 5  | FDTF1    | 0x0 | ro | Stream1 full data transfer complete interrupt flag |
| Bit 4  | HDTF1    | 0x0 | ro | Stream1 half data transfer complete interrupt flag |
| Bit 3  | DTERRF1  | 0x0 | ro | Stream1 transfer error interrupt flag              |
| Bit 2  | DMERRF1  | 0x0 | ro | Stream1 direct mode error interrupt flag           |
| Bit 1  | Reserved | 0x0 | ro | Kept at its default value.                         |
| Bit 0  | FERRF1   | 0x0 | ro | Stream1 fifo error interrupt flag                  |

## 29.5.2 DMA status register 2 (DMA\_STS2)

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     | FDTF8    | 0x0         | ro   | Stream8 full data transfer complete interrupt flag |
| Bit 26     | HDTF8    | 0x0         | ro   | Stream8 half transfer complete interrupt flag      |
| Bit 25     | DTERRF8  | 0x0         | ro   | Stream8 transfer error interrupt flag              |
| Bit 24     | DMERRF8  | 0x0         | ro   | Stream8 direct mode error interrupt flag           |
| Bit 23     | Reserved | 0x0         | ro   | Kept at its default value.                         |
| Bit 22     | FERRF8   | 0x0         | ro   | Stream8 fifo error interrupt flag                  |
| Bit 21     | FDTF7    | 0x0         | ro   | Stream7 full data transfer complete interrupt flag |
| Bit 20     | HDTF7    | 0x0         | ro   | Stream7 half data transfer complete interrupt flag |
| Bit 19     | DTERRF7  | 0x0         | ro   | Stream7 transfer error interrupt flag              |
| Bit 18     | DMERRF7  | 0x0         | ro   | Stream7 direct mode error interrupt flag           |
| Bit 17     | Reserved | 0x0         | ro   | Kept at its default value.                         |
| Bit 16     | FERRF7   | 0x0         | ro   | Stream7 fifo error interrupt flag                  |
| Bit 15: 12 | Reserved | 0x0         | resd | Kept at its default value.                         |
| Bit 11     | FDTF6    | 0x0         | ro   | Stream6 full data transfer complete interrupt flag |

|        |          |     |    |                                                    |
|--------|----------|-----|----|----------------------------------------------------|
| Bit 10 | HDTF6    | 0x0 | ro | Stream6 half data transfer complete interrupt flag |
| Bit 9  | DTERRF6  | 0x0 | ro | Stream6 transfer error interrupt flag              |
| Bit 8  | DMERRF6  | 0x0 | ro | Stream6 direct mode error interrupt flag           |
| Bit 7  | Reserved | 0x0 | ro | Kept at its default value.                         |
| Bit 6  | FERRF6   | 0x0 | ro | Stream6 fifo error interrupt flag                  |
| Bit 5  | FDTF5    | 0x0 | ro | Stream5 full data transfer complete interrupt flag |
| Bit 4  | HDTF5    | 0x0 | ro | Stream5 half data transfer complete interrupt flag |
| Bit 3  | DTERRF5  | 0x0 | ro | Stream5 transfer error interrupt flag              |
| Bit 2  | DMERRF5  | 0x0 | ro | Stream5 direct mode error interrupt flag           |
| Bit 1  | Reserved | 0x0 | ro | Kept at its default value.                         |
| Bit 0  | FERRF5   | 0x0 | ro | Stream5 fifo error interrupt flag                  |

### 29.5.3 DMA flag clear register 1 (DMA\_CLR1)

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     | FDTFC4   | 0x0         | w    | Stream4 clear transfer complete interrupt flag      |
| Bit 26     | HDTFC4   | 0x0         | w    | Stream4 clear half transfer complete interrupt flag |
| Bit 25     | DTERRFC4 | 0x0         | w    | Stream4 clear error interrupt flag                  |
| Bit 24     | DMERRFC4 | 0x0         | w    | Stream4 clear direct mode error interrupt flag      |
| Bit 23     | Reserved | 0x0         | resd | Kept at its default value.                          |
| Bit 22     | FERRFC4  | 0x0         | w    | Stream4 clear fifo error interrupt flag             |
| Bit 21     | FDTFC3   | 0x0         | w    | Stream3 clear transfer complete interrupt flag      |
| Bit 20     | HDTFC3   | 0x0         | w    | Stream3 clear half transfer complete interrupt flag |
| Bit 19     | DTERRFC3 | 0x0         | w    | Stream3 clear error interrupt flag                  |
| Bit 18     | DMERRFC3 | 0x0         | w    | Stream3 clear direct mode error interrupt flag      |
| Bit 17     | Reserved | 0x0         | resd | Kept at its default value.                          |
| Bit 16     | FERRFC3  | 0x0         | w    | Stream3 clear fifo error interrupt flag             |
| Bit 15: 12 | FDTFC2   | 0x0         | w    | Stream2 clear transfer complete interrupt flag      |
| Bit 11     | HDTFC2   | 0x0         | w    | Stream2 clear half transfer complete interrupt flag |
| Bit 10     | DTERRFC2 | 0x0         | w    | Stream2 clear error interrupt flag                  |
| Bit 9      | DMERRFC2 | 0x0         | w    | Stream2 clear direct mode error interrupt flag      |
| Bit 8      | Reserved | 0x0         | resd | Kept at its default value.                          |

|       |          |     |      |                                                     |
|-------|----------|-----|------|-----------------------------------------------------|
| Bit 7 | FERRFC2  | 0x0 | w    | Stream2 clear fifo error interrupt flag             |
| Bit 6 | Reserved | 0x0 | resd | Kept at its default value.                          |
| Bit 5 | FDTFC1   | 0x0 | w    | Stream1 clear transfer complete interrupt flag      |
| Bit 4 | HDTFC1   | 0x0 | w    | Stream1 clear half transfer complete interrupt flag |
| Bit 3 | DTERRFC1 | 0x0 | w    | Stream1 clear error interrupt flag                  |
| Bit 2 | DMERRFC1 | 0x0 | w    | Stream1 clear direct mode error interrupt flag      |
| Bit 1 | Reserved | 0x0 | resd | Kept at its default value.                          |
| Bit 0 | FERRFC1  | 0x0 | w    | Stream1 clear fifo error interrupt flag             |

## 29.5.4 DMA flag clear register 2 (DMA\_CLR2)

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     | FDTFC8   | 0x0         | w    | Stream8 clear transfer complete interrupt flag      |
| Bit 26     | HDTFC8   | 0x0         | w    | Stream8 clear half transfer complete interrupt flag |
| Bit 25     | DTERRFC8 | 0x0         | w    | Stream8 clear error interrupt flag                  |
| Bit 24     | DMERRFC8 | 0x0         | w    | Stream8 clear direct mode error interrupt flag      |
| Bit 23     | Reserved | 0x0         | resd | Kept at its default value.                          |
| Bit 22     | FERRFC8  | 0x0         | w    | Stream8 clear fifo error interrupt flag             |
| Bit 21     | FDTFC7   | 0x0         | w    | Stream7 clear transfer complete interrupt flag      |
| Bit 20     | HDTFC7   | 0x0         | w    | Stream7 clear half transfer complete interrupt flag |
| Bit 19     | DTERRFC7 | 0x0         | w    | Stream7 clear error interrupt flag                  |
| Bit 18     | DMERRFC7 | 0x0         | w    | Stream7 clear direct mode error interrupt flag      |
| Bit 17     | Reserved | 0x0         | resd | Kept at its default value.                          |
| Bit 16     | FERRFC7  | 0x0         | w    | Stream7 clear fifo error interrupt flag             |
| Bit 15: 12 | FDTFC6   | 0x0         | w    | Stream6 clear transfer complete interrupt flag      |
| Bit 11     | HDTFC6   | 0x0         | w    | Stream6 clear half transfer complete interrupt flag |
| Bit 10     | DTERRFC6 | 0x0         | w    | Stream6 clear error interrupt flag                  |
| Bit 9      | DMERRFC6 | 0x0         | w    | Stream6 clear direct mode error interrupt flag      |
| Bit 8      | Reserved | 0x0         | resd | Kept at its default value.                          |
| Bit 7      | FERRFC6  | 0x0         | w    | Stream6 clear fifo error interrupt flag             |
| Bit 6      | Reserved | 0x0         | resd | Kept at its default value.                          |
| Bit 5      | FDTFC5   | 0x0         | w    | Stream5 clear transfer complete interrupt flag      |

|       |          |     |      |                                                     |
|-------|----------|-----|------|-----------------------------------------------------|
| Bit 4 | HDTFC5   | 0x0 | w    | Stream5 clear half transfer complete interrupt flag |
| Bit 3 | DTERRFC5 | 0x0 | w    | Stream5 clear error interrupt flag                  |
| Bit 2 | DMERRFC5 | 0x0 | w    | Stream5 clear direct mode error interrupt flag      |
| Bit 1 | Reserved | 0x0 | resd | Kept at its default value.                          |
| Bit 0 | FERRFC5  | 0x0 | w    | Stream5 clear fifo error interrupt flag             |

## 29.5.5 DMA stream-x control register (DMA\_SxCTRL) (x= 1...8)

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: 25 | CHSEL    | 0x0         | rw   | channel select<br>000: Channel 1 selected<br>This field can be written only when SEN=0.                                                                                                                                                                                                                                                                                                                    |
| Bit 24: 23 | MBURST   | 0x0         | rw   | Memory burst transfer configuration<br>This field defines the type of memory burst transfer.<br>00: Single transfer<br>01: INCR4 (4-beat increment burst)<br>10: INCR8 (beat increment burst)<br>11: INCR16 (16-beat increment burst)<br>This field is forced to 00 when SEN=1.<br>Note: This field can be written only when SEN=0.                                                                        |
| Bit 22: 21 | PBURST   | 0x0         | rw   | Peripheral burst transfer configuration<br>This field defines the type of peripheral transfers.<br>00: Single transfer<br>01: INCR4 (4-beat increment burst)<br>10: INCR8 (beat increment burst)<br>11: INCR16 (16-beat increment burst)<br>This field is forced to 00 when SEN=1.<br>Note: This field can be written only when SEN=0.                                                                     |
| Bit 20     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                                                                                                                                                                                 |
| Bit 19     | CM       | 0x0         | rw   | Current memory<br>This bit is valid in dual buffer mode only.<br>0: Current target is memory 0 (addressed by the DMA_SxM0ADDR)<br>1: Current target is memory 1 (addressed by the DMA_SxM1ADDR)<br>This bit can be written only when SEN=0 to indicate the target memory area of the first transfer.<br>Once SEN=1, this bit is used as a status flag, indicating which is the current target memory area. |
| Bit 18     | DMM      | 0x0         | rw   | Double memory mode<br>0: Double memory mode disabled<br>1: Double memory mode enabled<br>This bit can be written only when SEN=0.                                                                                                                                                                                                                                                                          |
| Bit 17: 16 | SPL      | 0x0         | rw   | Stream polarity<br>00: Low<br>01: Medium<br>10: High<br>11: Very high<br>This field can be written only when SEN=0.                                                                                                                                                                                                                                                                                        |

|            |        |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|--------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 15     | PINCOS | 00x | rw | Peripheral increase offset<br>0: Peripheral increase offset disabled<br>1: Peripheral increase offset enabled<br>If PINCOS bit is enabled, the offset size of the peripheral address calculation is fixed to 32-bit alignment. This bit has no meaning if PINCM=0.<br>This bit is forced low by hardware when the direction mode is selected or if PBURST is different from 00.<br>This bit can be written only when SEN=0. |
| Bit 14: 13 | MWIDTH | 0x0 | rw | Memory data width<br>This field defines the HSIZE (AHB bus signal) in the memory controller.<br>00: Byte (8-bit)<br>01: Half-word (16-bit)<br>10: Word (32-bit)<br>11: Reserved<br>In direct mode, this field is forced by hardware to be same value as PWIDTH when SEN=1.<br><small>This field can be written only when SEN=0</small>                                                                                      |
| Bit 12: 11 | PWIDTH | 00x | rw | peripheral data width<br>This field defines the HSIZE (AHB bus signal) in the peripheral controller.<br>00: Byte (8-bit)<br>01: Half-word (16-bit)<br>10: Word (32-bit)<br>11: Reserved<br>This field can be written only when SEN=0.                                                                                                                                                                                       |
| Bit 10     | MINCM  | 0x0 | rw | Memory increment mode<br>0: Memory address pointer is fixed<br>1: Memory address pointer is incremented<br>This bit can be written only when SEN=0.                                                                                                                                                                                                                                                                         |
| Bit 9      | PINCM  | 0x0 | rw | peripheral increment mode<br>0: Peripheral address pointer is fixed<br>1: Peripheral address pointer is incremented<br>This bit can be written only when SEN=0.                                                                                                                                                                                                                                                             |
| Bit 8      | LM     | 0x0 | rw | Loop mode<br>0: Loop mode is disabled<br>1: Loop mode is enabled<br>This bit is forced low by hardware if PFCTRL=1, as soon as SEN=1.<br>This bit is forced high by hardware if DMM=1, as soon as SEN=1.                                                                                                                                                                                                                    |
| Bit 7: 6   | DTD    | 0x0 | rw | data transfer direction<br>00: Peripheral to memory (P2M)<br>01: Memory to peripheral (M2P)<br>10: Memory to memory (M2M)<br>11: Reserved<br>This bit can be written only when SEN=0.                                                                                                                                                                                                                                       |
| Bit 5      | PFCTRL | 0x0 | rw | Peripheral flow controller<br>0: DMA is the flow controller<br>1: The peripheral is the flow controller<br>This bit is forced low by hardware if DTD=10 (M2M).<br>This bit can be written only when SEN=0.                                                                                                                                                                                                                  |
| Bit 4      | FDTIEN | 0x0 | rw | Full data transfer interrupt enable<br>0: TC interrupt disabled<br>1: TC interrupt enabled                                                                                                                                                                                                                                                                                                                                  |
| Bit 3      | HDTIEN | 0x0 | rw | Half data transfer interrupt enable<br>0: HT interrupt disabled<br>1: HT interrupt enabled                                                                                                                                                                                                                                                                                                                                  |

|       |          |     |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 2 | DTERRIEN | 0x0 | rw | Data transfer error interrupt enable<br>0: TE interrupt disabled<br>1: TE interrupt enabled                                                                                                                                                                                                                                                                                                                                                      |
| Bit 1 | DMERRIEN | 0x0 | rw | Direct mode error interrupt enable<br>0: DME interrupt disabled<br>1: DME interrupt enabled                                                                                                                                                                                                                                                                                                                                                      |
| Bit 0 | SEN      | 0x0 | rw | Stream enable<br>0: Stream disabled<br>1: Stream enabled<br>This bit may be cleared by hardware under the following conditions:<br>-DMA end of transfer<br>-If a transfer error occurs on the AHB master buses<br>-When the FIFO threshold on memory AHB port is not compatible with the burst size.<br>Note: Before setting SEN=1 to start a new transfer, the event flags corresponding to the stream in DMA_STS1 or DMA_STS2 must be cleared. |

## 29.5.6 DMA stream-x data register (DMA\_SxDTCNT) (x= 1...8)

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   | Number of data to be transferred 0~65535<br>This register can be written only when SEN=0.<br>This register is read-only when SEN=1, indicating the remaining data to be transmitted. This register is decremented after each transfer.<br>Typically, this register remains 0 after the completion of data transfer. But this register may be automatically reloaded with the previously programmed value in the following cases:<br>·When the stream is configured to be loop mode<br>·When the stream is enabled again by setting SEN=1.<br>If this register is zero, no transaction can be served even if SEN=1 |

## 29.5.7 DMA stream-x peripheral address register (DMA\_SxPADDR) (x= 1...8)

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

| Bit       | Name  | Reset value | Type | Description                                                                                               |
|-----------|-------|-------------|------|-----------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | PADDR | 0x0000 0000 | rw   | Peripheral address<br>Base address of the peripheral address.<br>This field can be written only if SEN=0. |

## 29.5.8 DMA stream-x memory 0 address register (DMA\_SxM0ADDR) (x= 1...8)

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

| Bit       | Name   | Reset value | Type | Description                                                                                                                                                                           |
|-----------|--------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | M0ADDR | 0x0000 0000 | rw   | Memory 0 address<br>Base address of memory area 0.<br>This field can be written only if:<br>·The stream is disabled (SEN =0)<br>·The stream is enabled in dual buffer mode, and CM=1. |

## 29.5.9 DMA stream-x memory 1 address register (DMA\_SxM1ADDR) (x= 1...8)

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

| Bit       | Name   | Reset value | Type | Description                                                                                                                                                                           |
|-----------|--------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | M1ADDR | 0x0000 0000 | rw   | Memory 1 address<br>Base address of memory area 1.<br>This field can be written only if:<br>·The stream is disabled (SEN =0)<br>·The stream is enabled in dual buffer mode, and CM=1. |

## 29.5.10 DMA stream-x FIFO control register (DMA\_SxFCTRL) (x= 1...8)

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

| Bit       | Name     | Reset value | Type | Description                                                                                                                                                                                                                                   |
|-----------|----------|-------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 8 | Reserved | 0x0000 00   | resd | Kept at its default value.                                                                                                                                                                                                                    |
| Bit 7     | FERRIEN  | 0x0         | rw   | FIFO error interrupt enable<br>0: FIFO error interrupt disabled<br>1: FIFO error interrupt enabled                                                                                                                                            |
| Bit 6     | Reserved | 0x0         | resd | Kept at its default value.                                                                                                                                                                                                                    |
| Bit 5: 3  | FSTS     | 0x4         | rw   | FIFO status<br>000: 0 <fifo_level <1/4<br>001: 1/4≤fifo_level <1/2<br>010: 1/2≤fifo_level <3/4<br>011: 3/4≤fifo_level < full<br>100: FIFO empty<br>101: FIFO full<br>Others: No meaning<br>These bits are not relevant in direct mode (FEN=0) |
| Bit 2     | FEN      | 0x0         | rw   | FIFO mode enable<br>0: Direct mode<br>1: FIFO mode<br>This bit is set by hardware if memory-to-memory mode is selected (DTD=10) and SEN=1.                                                                                                    |
| Bit 1: 0  | FTHSEL   | 0x1         | rw   | FIFO threshold select<br>00: 1/4 full FIFO<br>01: 1/2 full FIFO<br>10: 3/4 full FIFO<br>11: full FIFO<br>These bits are not used in direct mode (FEN=0).<br>These bits cannot be written only if SEN=0.                                       |

### 29.5.11 DMA linked table control register (DMA\_SxLLCTRL)

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

| Bit       | Name     | Reset value | Type | Description                |
|-----------|----------|-------------|------|----------------------------|
| Bit 31: 8 | Reserved | 0x0         | resd | Kept at its default value. |
| Bit 7     | S8LLEN   | 0x0         | rw   | Stream8 link list enable   |
| Bit 6     | S7LLEN   | 0x0         | rw   | Stream7 link list enable   |
| Bit 5     | S6LLEN   | 0x0         | rw   | Stream6 link list enable   |
| Bit 4     | S5LLEN   | 0x0         | rw   | Stream5 link list enable   |
| Bit 3     | S4LLEN   | 0x0         | rw   | Stream4 link list enable   |
| Bit 2     | S3LLEN   | 0x0         | rw   | Stream3 link list enable   |
| Bit 1     | S2LLEN   | 0x0         | rw   | Stream2 link list enable   |
| Bit 0     | S1LLEN   | 0x0         | rw   | Stream1 link list enable   |

### 29.5.12 DMA linked table pointer register (DMA\_SxLLP) (x = 1...8)

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

| Bit       | Name | Reset value | Type | Description                                                                                                                                            |
|-----------|------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 0 | LLP  | 0x0000 0000 | rw   | link list pointer<br>After the completion of the current descriptor, the flow controller uses this pointer as a target address to read the descriptor. |

### 29.5.13 DMA 2D transfer control register (DMA\_S2DCTRL)

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

| Bit       | Name     | Reset value | Type | Description                |
|-----------|----------|-------------|------|----------------------------|
| Bit 31: 8 | Reserved | 0x0         | resd | Kept at its default value. |
| Bit 7     | S82DEN   | 0x0         | rw   | Stream8 2D enable          |
| Bit 6     | S72DEN   | 0x0         | rw   | Stream7 2D enable          |
| Bit 5     | S62DEN   | 0x0         | rw   | Stream6 2D enable          |
| Bit 4     | S52DEN   | 0x0         | rw   | Stream5 2D enable          |
| Bit 3     | S42DEN   | 0x0         | rw   | Stream4 2D enable          |
| Bit 2     | S32DEN   | 0x0         | rw   | Stream3 2D enable          |
| Bit 1     | S22DEN   | 0x0         | rw   | Stream2 2D enable          |
| Bit 0     | S12DEN   | 0x0         | rw   | Stream1 2D enable          |

### 29.5.14 DMA 2D transfer count register (DMA\_S2DCNT)

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

| Bit        | Name   | Reset value | Type | Description  |
|------------|--------|-------------|------|--------------|
| Bit 31: 16 | YCOUNT | 0x0000      | rw   | C-axis count |
| Bit 15: 0  | XCOUNT | 0x0000      | rw   | X-axis count |

## 29.5.15 DMA 2D transfer stride register (DMA\_STRIDE)( x = 1...8)

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

| Bit        | Name   | Reset value | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|--------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 16 | DSTSTD | 0x0000      | rw   | <p>Destination stride<br/>This is a signed value (two's complement).<br/>0x0000: 0<br/>...<br/>0x7FFF:32767<br/>0x8000:-32768<br/>0x8001:-32767<br/>...<br/>0xFFFF:-1</p> <p>The DST value is in terms of byte address. For example, if the destination stride is 0x8, the destination byte address is added with 0x8 before the next iteration.<br/>DSTSTD bit 1..0 must be 00, for the size of the destination position remains word.</p> |
| Bit 15: 0  | SRCSTD | 0x0000      | rw   | <p>Source stride<br/>This is a signed value (two's complement).<br/>0x0000: 0<br/>...<br/>0x7FFF:32767<br/>0x8000:-32768<br/>0x8001:-32767<br/>...<br/>0xFFFF:-1</p> <p>The SRC value is in terms of byte address. For example, if the source stride is 0x8, the source byte address is added with 0x8 before the next iteration.<br/>SRCSTD bit 1..0 must be 00, for the size of the source position remains word.</p>                     |

## 29.5.16 DMA synchronization enable (DMA\_SYNCEN)

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

| Bit       | Name     | Reset value | Type | Description                    |
|-----------|----------|-------------|------|--------------------------------|
| Bit 31: 8 | Reserved | 0x0         | resd | Kept at its default value.     |
| Bit 7     | S8SYNC   | 0x0         | rw   | Stream8 synchronization enable |
| Bit 6     | S7SYNC   | 0x0         | rw   | Stream7 synchronization enable |
| Bit 5     | S6SYNC   | 0x0         | rw   | Stream6 synchronization enable |
| Bit 4     | S5SYNC   | 0x0         | rw   | Stream5 synchronization enable |
| Bit 3     | S4SYNC   | 0x0         | rw   | Stream4 synchronization enable |
| Bit 2     | S3SYNC   | 0x0         | rw   | Stream3 synchronization enable |
| Bit 1     | S2SYNC   | 0x0         | rw   | Stream2 synchronization enable |
| Bit 0     | S1SYNC   | 0x0         | rw   | Stream1 synchronization enable |

## 29.5.17 DMAMUX table select (DMA\_MUXSEL)

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

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

## 29.5.18 DMAMUX channel-x control register (DMA\_MUXSxCTRL) (x = 1...8)

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

| Bit        | Name      | Reset value | Type | Description                                                                                                                                                                                            |
|------------|-----------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 31: 25 | Reserved  | 0x0         | resd | Kept at its default value.                                                                                                                                                                             |
| Bit 28: 24 | SYNCSEL   | 0x0         | rw   | Synchronization select                                                                                                                                                                                 |
| Bit 23: 19 | REQCNT    | 0x0         | rw   | DMA request count<br>This field defines the number of DMA requests after synchronization events and/or before synchronization events.<br>This field are reserved only if SYNCEN and EVTGEN both are 0. |
| Bit 18: 17 | SYNCPOL   | 0x0         | rw   | Synchronization polarity<br>Defines the polarity of the selected synchronization input.<br>0x0: No event<br>0x1: Rising edge<br>0x2: Falling edge<br>0x3: Rising and falling edge                      |
| Bit 16     | SYNCEN    | 0x0         | rw   | Synchronization enable<br>0: Synchronization disabled<br>1: Synchronization enabled                                                                                                                    |
| Bit 15: 10 | Reserved  | 0x00        | resd | Kept at its default value.                                                                                                                                                                             |
| Bit 9      | EVTGEN    | 0x0         |      | Event generation enable<br>0: Event generation disabled<br>1: Event generation 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>Select a DMA request Refer to DMAMUX table for more information.                                                                                                                 |

## 29.5.19 DMAMUX generator-x control register (DMA\_MUXGxCTRL) (x = 1...8)

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>Defines the number of DMA requests (GREQCNT + 1)<br>after an event occurs.<br>This field is reserved only when GEN is disabled.                   |
| Bit 18: 17 | GPOL     | 0x0         | rw   | DMA request generation polarity<br>Defines the polarity of the selected trigger inputs.<br>0x0: No event<br>0x1: Rising edge<br>0x2: Falling edge<br>0x3: Rising and falling edge |
| Bit 16     | GEN      | 0x0         | rw   | DMA request generation enable<br>0: DMA request generation disabled<br>1: DMA request generation 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>This field is used to select DMA signal for DMA request generation.                                                                                              |

## 29.5.20 DMAMUX synchronization interrupt status register (DMA\_MUXSYNCSTS)

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

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

## 29.5.21 DMAMUX synchronization interrupt clear flag register (BPR\_MUXSYNCCLR)

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

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

## 29.5.22 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: 8 | Reserved | 0x0000 000  | resd | Kept at its default value.                                                                                                         |
| Bit 7: 0  | TRGOVF   | 0x00        | ro   | Trigger overrun interrupt flag<br>This bit is set when a new trigger event occurs while the DMA request count is below the GNBREQ. |

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

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

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

# 30 Debug (DEBUG)

## 30.1 Debug introduction

Cortex®-M4F core provides powerful debugging features including halt and single step support, as well as trace function that is used for checking the details of the program execution. The debug features are implemented with two interfaces: serial wire debug (SWD) and JTAG debug port. Trace information is collected by a single-wire serial wire view interface, or by TRACE interface when a larger trace bandwidth is needed. Trace and debugging interfaces can be combined into one 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

## 30.2 Debug and Trace

It is possible to support debugging for different peripherals, and configure the status of peripherals during debugging. For timers and watchdogs, the user can select whether or not to stop or continue counting during debugging; For CAN, the user can select whether or not to stop or continue updating receive registers during debugging; For I2C, 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.

Two trace interface modes supported: single-pin mode for serial wire view and multi-pin trace interface.

## 30.3 I/O pin control

SWJ-DP debug is supported in different packages of AT32F435/437. It uses 5 general-purpose I/O ports. After reset, the SWJ-DP can be immediately used by the debugger as a default function. To ensure that JTAG input pins are not floating (particularly SWCLK/JTCK), the JTAG input pins are embedded with internal pull-up or pull-down feature, NJTRST, JTDI and JTMS/SWDIO with internal pull-up feature, and JTCK/SWCLK with internal pull-down feature.

GPIO and IOMUX registers can be configured to allow users to switch between debug ports or disable debug feature.

## 30.4 DEGUB registers

Table 30-1 shows DEBUG register map and reset values.

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

Table 30-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 |

### 30.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 JTAG debug port or SW debug port or by the user code.

| Bit       | Name | Reset value | Type | Description     |
|-----------|------|-------------|------|-----------------|
| Bit 31: 0 | PID  | 0xFFFF XXXX | ro   | PID information |

| PID [31: 0] | AT32 part number | FLASH size | Packages |
|-------------|------------------|------------|----------|
| 0x7008_4540 | AT32F435ZMT7     | 4032KB     | LQFP144  |
| 0x7008_3341 | AT32F435ZGT7     | 1024KB     | LQFP144  |
| 0x7008_4598 | AT32F435ZDT7     | 448KB      | LQFP144  |
| 0x7008_3242 | AT32F435ZCT7     | 256KB      | LQFP144  |
| 0x7008_4543 | AT32F435VMT7     | 4032KB     | LQFP100  |
| 0x7008_3344 | AT32F435VGT7     | 1024KB     | LQFP100  |
| 0x7008_4599 | AT32F435VDT7     | 448KB      | LQFP100  |
| 0x7008_3245 | AT32F435VCT7     | 256KB      | LQFP100  |
| 0x7008_4546 | AT32F435RMT7     | 4032KB     | LQFP64   |
| 0x7008_3347 | AT32F435RGT7     | 1024KB     | LQFP64   |
| 0x7008_459A | AT32F435RDT7     | 448KB      | LQFP64   |
| 0x7008_3248 | AT32F435RCT7     | 256KB      | LQFP64   |
| 0x7008_4549 | AT32F435CMT7     | 4032KB     | LQFP48   |
| 0x7008_334A | AT32F435CGT7     | 1024KB     | LQFP48   |
| 0x7008_459B | AT32F435CDT7     | 448KB      | LQFP48   |
| 0x7008_324B | AT32F435CCT7     | 256KB      | LQFP48   |
| 0x7008_454C | AT32F435CMU7     | 4032KB     | QFN48    |
| 0x7008_334D | AT32F435CGU7     | 1024KB     | QFN48    |
| 0x7008_459C | AT32F435CDU7     | 448KB      | QFN48    |
| 0x7008_324E | AT32F435CCU7     | 256KB      | QFN48    |
| 0x7008_454F | AT32F437ZMT7     | 4032KB     | LQFP144  |
| 0x7008_3350 | AT32F437ZGT7     | 1024KB     | LQFP144  |
| 0x7008_459D | AT32F437ZDT7     | 448KB      | LQFP144  |
| 0x7008_3251 | AT32F437ZCT7     | 256KB      | LQFP144  |
| 0x7008_4552 | AT32F437VMT7     | 4032KB     | LQFP100  |
| 0x7008_3353 | AT32F437VGT7     | 1024KB     | LQFP100  |
| 0x7008_459E | AT32F437VDT7     | 448KB      | LQFP100  |
| 0x7008_3254 | AT32F437VCT7     | 256KB      | LQFP100  |
| 0x7008_4555 | AT32F437RMT7     | 4032KB     | LQFP64   |
| 0x7008_3356 | AT32F437RGT7     | 1024KB     | LQFP64   |
| 0x7008_459F | AT32F437RDT7     | 448KB      | LQFP64   |
| 0x7008_3257 | AT32F437RCT7     | 256KB      | LQFP64   |

### 30.4.2 DEBUG control register (DEBUG\_CTRL)

This register is asynchronously reset by POR Reset (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.                                                                                                                                                                                                                                                                                                                     |

### 30.4.3 DEBUG APB1 pause register (DEBUG\_APB1\_PAUSE)

This register is asynchronously reset by POR Reset (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 its 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     | CAN2_PAUSE         | 0x0         | rw   | CAN2 pause control bit<br>0: CAN2 works normally<br>1: CAN2 receive register pauses (does not receive data)                                                  |
| 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 its default value.                                                                                                                                   |
| Bit 15     | ERTC_512_PAUSE     | 0x0  | rw   | ERTC 512Hz output clock pause control bit<br>0: ERTC 512Hz output clock works normally<br>1: Froze 512Hz output clock                                        |
| Bit 14: 13 | Reserved           | 0x0  | rw   | Kept at its 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  | rw   | Kept at its 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      | TMR12_PAUSE        | 0x0  | rw   | TMR12 pause control bit<br>0: TMR12 works normally<br>1: TMR12 stops running                                                                                 |
| 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      | TMR5_PAUSE         | 0x0  | rw   | TMR5 pause control bit<br>0: TMR5 works normally<br>1: TMR5 stops running                                                                                    |
| 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                                                                                    |

### 30.4.4 DEBUG APB2 pause register (DEBUG\_APB2\_PAUSE)

This register is asynchronously reset by POR Reset (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 its 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: 7  | Reserved    | 0x000       | resd | Kept at its default value.                                                   |
| Bit 6      | TMR20_PAUSE | 0x0         | rw   | TMR20 pause control bit<br>0: TMR20 works normally<br>1: TMR20 stops running |
| Bit 5: 2   | Reserved    | 0x0         | resd | Kept at its default value.                                                   |
| Bit 1      | TMR8_PAUSE  | 0x0         | rw   | TMR8 pause control bit<br>0: TMR8 works normally<br>1: TMR8 stops running    |
| Bit 0      | TMR1_PAUSE  | 0x0         | rw   | TMR1 pause control bit<br>0: TMR2 works normally<br>1: TMR2 stops running    |

### 30.4.5 DEBUG SERIES ID register (DEBUG\_SER\_ID)

DEBUG\_SIE\_ID register is used to identify MCU part number and its revision code. The DEBUG\_IDCODE register is mapped on the external PPB bus. This register is asynchronously reset by POR Reset (not reset by system reset). This code is accessible by the JTAG debug port or SW debug port or by the user code.

| Bit        | Name     | Reset value | Type | Description                                            |
|------------|----------|-------------|------|--------------------------------------------------------|
| Bit 31: 16 | Reserved | 0x0000      | resd | Kept at its default value.                             |
| Bit 15: 8  | SER_ID   | 0xXX        | ro   | MCU part number ID<br>AT32F435: 0x0D<br>AT32F437: 0x0E |
| Bit 7: 3   | Reserved | 0x0X        | resd | Kept at its default value.                             |
| Bit 2: 0   | REV_ID   | 0xX         | ro   | Revision code<br>0x0: Revision A                       |

# 31 Revision history

Document Revision History

| Date       | Version | Revision Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.06.30 | 2.00    | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2021.12.01 | 2.01    | Updated I2C description, and revised some typos.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2022.06.27 | 2.02    | <ul style="list-style-type: none"><li>1. Updated <a href="#">Section 13 Serial peripheral interface (SPI)</a> by adding SPI timing diagram.</li><li>2. Updated <a href="#">Section 5.1 FLASH introduction</a>.</li><li>3. Updated <a href="#">Section 13.2.6 DMA transfer</a></li><li>4. Updated <a href="#">Section 11.7.2 Control register 2 (I2C_CTRL2)</a></li><li>5. Updated <a href="#">Figure 24-2</a></li><li>6. Updated <a href="#">Table 6-2</a></li><li>7. Updated <a href="#">Table 24-31</a></li><li>8. Updated <a href="#">Figure 1-1</a></li><li>9. Updated <a href="#">Section 20.6.7 Error management</a></li><li>10. Updated <a href="#">Section 20.7 CAN registers</a></li><li>11. Updated <a href="#">Section 24.8.1.5 SRAM/NOR Flash extra timing register x (XMC_EXTx) (x=1,2,3,4)</a></li><li>12. Updated <a href="#">11.7.1 Control register 1 (I2C_CTRL1)</a></li></ul> |
| 2022.11.11 | 2.03    | <ul style="list-style-type: none"><li>1. Updated descriptions of <a href="#">Chapter 4</a></li><li>2. Updated descriptions of <a href="#">Chapter 10</a></li><li>3. Updated descriptions of <a href="#">Chapter 14</a></li><li>4. Updated descriptions of <a href="#">Chapter 17</a></li><li>5. Updated descriptions of <a href="#">Section 18.2</a></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2023.04.10 | 2.04    | <ul style="list-style-type: none"><li>1. Added Table-3 448KB Flash memory architecture in <a href="#">Section 5.1 FLASH introduction</a></li><li>2. Modified the reset value of <a href="#">section 22.6.4 Control register 2 (ACC_CTRL2)</a></li><li>3. Updated Table 6-1 in <a href="#">Section 6.2.9 IOMUX input/output</a></li><li>4. Updated the descriptions of <a href="#">Section 18 Analog-to-digital converter (ADC)</a></li><li>5. Updated the descriptions of <a href="#">Section 11 I2C interface</a></li><li>6. Updated the descriptions of Table 5-5 in <a href="#">Section 5.1 FLASH introduction</a></li><li>7. Updated the descriptions of <a href="#">Section 28 Qud-SPI interface (QSPI)</a></li><li>8. Updated the descriptions of <a href="#">Section 26 Ethernet media access control (EMAC)</a></li></ul>                                                                |
| 2023.08.02 | 2.05    | <ul style="list-style-type: none"><li>1. Updated the descriptions of <a href="#">Section 14 Timer</a></li><li>2. Updated the descriptions of <a href="#">Section 12.8.3 Start bit and noise detection</a></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2024.06.24 | 2.06    | <ul style="list-style-type: none"><li>1. Updated the descriptions of <a href="#">Section 5.5 Special functions</a></li><li>2. Updated the descriptions of <a href="#">Section 6 GPIOs and IOMUX</a></li><li>3. Updated the descriptions of <a href="#">Section 9.4.1 DMAMUX functional overview</a></li><li>4. Updated the descriptions of <a href="#">Section 12.7 Transmitter</a></li><li>5. Updated the descriptions of <a href="#">Section 23 Infrared timer (IRTMR)</a></li><li>6. Updated the descriptions of <a href="#">Section 28 Qud-SPI interface (QSPI)</a></li><li>7. Updated the descriptions of <a href="#">Section 29.4.1 DMAMUX functional overview</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.

© 2024 ARTERY Technology - All Rights Reserved.